.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:6px;font-family:Inter,sans-serif;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap;width:100%}.ui-btn:disabled{opacity:.6;cursor:not-allowed}.ui-btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.ui-btn-primary{background-color:var(--primary-color);color:#fff;border-color:transparent}.ui-btn-primary:hover:not(:disabled){background-color:var(--primary-color-hover)}.ui-btn-secondary{background-color:var(--surface-color);color:var(--text-color);border-color:var(--border-color)}.ui-btn-secondary:hover:not(:disabled){background-color:var(--background-color);border-color:var(--subtle-text-color)}.ui-btn-ghost{background-color:transparent;color:var(--subtle-text-color);border-color:transparent}.ui-btn-ghost:hover:not(:disabled){background-color:#ffffff0d;color:var(--text-color)}.ui-btn-danger{background-color:transparent;color:var(--danger-color);border-color:var(--danger-color)}.ui-btn-danger:hover:not(:disabled){background-color:var(--danger-color);color:#fff}.ui-btn-sm{height:32px;padding:0 12px;font-size:13px}.ui-btn-md{height:40px;padding:0 16px;font-size:14px}.ui-btn-lg{height:48px;padding:0 24px;font-size:16px}.ui-btn-icon{padding:0;width:var(--height);flex-shrink:0}.ui-btn-sm.ui-btn-icon{width:32px}.ui-btn-md.ui-btn-icon{width:40px}.ui-btn-lg.ui-btn-icon{width:48px}.ui-input-wrapper{display:flex;flex-direction:column;gap:6px;width:100%}.ui-label{font-size:13px;font-weight:500;color:var(--text-color)}.ui-input{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;color:var(--text-color);font-size:14px;font-family:inherit;transition:border-color .2s ease;width:100%}.ui-input:focus{outline:none;border-color:var(--primary-color)}.ui-input:disabled{opacity:.6;cursor:not-allowed}.ui-input-error{border-color:var(--error-color)}.ui-error-msg{font-size:12px;color:var(--error-color)}.ui-panel{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.ui-panel-header{padding:12px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;background-color:#ffffff05}.ui-panel-title{font-size:14px;font-weight:600;color:var(--text-color);margin:0}.ui-panel-content{padding:16px}.bottom-sheet-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:2000;opacity:0;transition:opacity .3s ease;display:flex;align-items:flex-end;justify-content:center;pointer-events:none}.bottom-sheet-overlay.open{opacity:1;pointer-events:auto}.bottom-sheet{background-color:var(--surface-color);width:100%;max-width:600px;max-height:80vh;border-radius:16px 16px 0 0;transform:translateY(100%);transition:transform .3s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;box-shadow:0 -4px 20px #0000004d}.bottom-sheet.open{transform:translateY(0)}.bottom-sheet-handle{width:40px;height:4px;background-color:var(--border-color);border-radius:2px;margin:12px auto;flex-shrink:0;cursor:grab}.bottom-sheet-header{padding:0 16px 12px;font-size:18px;font-weight:600;text-align:center;border-bottom:1px solid var(--border-color);color:var(--text-color)}.bottom-sheet-content{padding:16px;overflow-y:auto;flex-grow:1}:root{--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--panel-bg-color: var(--surface-color);--hover-bg-color: #3a3a3e;--mobile-panel-width: 280px;--mobile-panel-transition: transform .3s ease-in-out}@media (max-width: 767px){.app-container{position:relative;overflow:hidden;height:100vh;height:100dvh}.mobile-panel-wrapper{position:fixed;top:0;height:100dvh;width:var(--mobile-panel-width);z-index:1000;background:var(--panel-bg-color);box-shadow:2px 0 8px #0000004d;transition:var(--mobile-panel-transition);padding-top:50px}.mobile-panel-wrapper.left{left:0;transform:translate(-100%)}.mobile-panel-wrapper.right{left:auto;right:0;transform:translate(100%)}.mobile-panel-wrapper.bottom{top:auto;bottom:0;left:0;right:0;width:100%;height:60dvh;max-height:60dvh;transform:translateY(100%);box-shadow:0 -2px 8px #0000004d;padding-top:0}.mobile-panel-wrapper.mobile-active{transform:translate(0)}.mobile-panel-wrapper.bottom.mobile-active{transform:translateY(0)}.mobile-panel-wrapper .panel-content{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;padding:0;-webkit-overflow-scrolling:touch}.mobile-panel-wrapper .controls-panel,.mobile-panel-wrapper .component-library-panel,.mobile-panel-wrapper .log-panel{width:100%!important;height:100%;padding:0;border:none;overflow-y:auto}.mobile-panel-wrapper.left .controls-panel{height:auto!important;min-height:100%;padding:12px!important;overflow-y:visible!important;display:flex;flex-direction:column}.mobile-header{position:fixed;top:0;left:0;right:0;height:50px;background:var(--panel-bg-color);border-bottom:1px solid var(--border-color);z-index:1001;display:flex;align-items:center;padding:0 var(--space-md);justify-content:space-between}.hamburger-menu{background:none;border:none;color:var(--text-color);font-size:1.5rem;padding:var(--space-sm)}.modal-overlay{align-items:flex-end;padding:0}.modal-content{width:100%;max-width:100%;border-radius:16px 16px 0 0;margin:0;max-height:85vh;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}body{font-size:var(--text-base)}h1{font-size:1.5rem}.splitter,.canvas-controls{display:none!important}.canvas-toolbar{top:60px!important;left:10px!important;max-width:calc(100% - 20px);overflow-x:auto}.library-category-group{margin-bottom:var(--space-lg);border:1px solid var(--border-color);border-radius:8px;padding:12px;max-width:100%;box-sizing:border-box}.category-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.category-name-input{flex:1;min-width:0;width:100%}.library-edit-item{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--border-color);border-radius:6px;margin-bottom:8px;background:#ffffff05}.library-edit-item input{width:100%!important;min-width:0;min-height:40px;font-size:16px}.library-edit-item .abbr-input{width:100%!important;text-align:left}.library-edit-item .delete-component-btn{align-self:flex-end;padding:8px}.button-add-item,.button-add-category{width:100%;min-height:44px}}@media (min-width: 768px){.mobile-panel-wrapper,.mobile-panel-wrapper .panel-content{display:contents}.controls-panel,.component-library-panel{height:auto;border-left:1px solid var(--color-border);border-right:1px solid var(--color-border)}.main-content-area>.controls-panel{border-right:1px solid var(--color-border);border-left:none}.mobile-header,.panel-overlay,.touch-controls,.mobile-export-buttons{display:none!important}.splitter,.library-toggle-button,.canvas-controls{display:block}.canvas-controls,.library-toggle-button{display:flex}}@media (max-width: 767px){.settings-modal{width:100%;height:90vh;max-height:90vh;border-radius:16px 16px 0 0}.settings-tabs{overflow-x:auto;padding:0 var(--space-md)}.settings-content{padding:var(--space-md)}}:root{--background-color: #1a1a1a;--surface-color: #2a2a2e;--primary-color: #00aaff;--primary-color-hover: #0088cc;--selected-color: #ffab00;--danger-color: #ff4d4d;--danger-color-hover: #cc3d3d;--text-color: #f0f0f0;--subtle-text-color: #888;--border-color: #444;--grid-color: #333;--error-color: #ff4d4d;--success-color: #4dff88}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:Inter,sans-serif;background-color:var(--background-color);color:var(--text-color);height:100%;overflow:hidden}#root{display:flex;height:100vh;width:100vw}.app-container{display:flex;flex-direction:column;flex-grow:1;overflow:hidden}.main-content-area{display:flex;flex-grow:1;height:100%;overflow:hidden}.editor-area{display:flex;flex-grow:1;height:100%;min-width:0}.controls-panel{flex-shrink:0;padding:12px;background-color:var(--surface-color);display:flex;flex-direction:column;gap:20px;overflow-y:auto;min-width:250px;max-width:600px}.splitter{width:5px;background-color:var(--border-color);cursor:col-resize;flex-shrink:0;transition:background-color .2s}.splitter:hover{background-color:var(--primary-color)}.controls-panel h1{font-size:24px;color:var(--text-color);margin-bottom:-8px}.controls-panel p{color:var(--subtle-text-color);font-size:14px;line-height:1.5}.prompt-group{display:flex;flex-direction:column;gap:8px}.prompt-group-header{display:flex;justify-content:space-between;align-items:center}.prompt-group-header label{font-weight:500}.add-context-button{padding:6px 12px;font-size:13px;min-width:auto;flex:0 1 auto}.prompt-textarea{height:150px;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:8px;padding:12px;color:var(--text-color);font-family:Roboto Mono,monospace;font-size:14px;resize:vertical;transition:border-color .2s}.prompt-textarea:focus{outline:none;border-color:var(--primary-color)}.example-prompts{display:flex;flex-direction:column;gap:8px}.example-prompts p{color:var(--subtle-text-color);font-size:14px;margin:0}.example-chips-container{display:flex;flex-wrap:wrap;gap:8px}.example-chip{background-color:var(--background-color);border:1px solid var(--border-color);color:var(--subtle-text-color);padding:6px 12px;border-radius:16px;font-size:12px;cursor:pointer;transition:all .2s ease;text-align:left}.example-chip:hover:not(:disabled){background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.example-chip:disabled{opacity:.5;cursor:not-allowed}.context-files-list{margin-top:8px;border:1px solid var(--border-color);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px;background-color:var(--background-color)}.context-list-header{font-size:12px!important;margin:0 0 4px!important}.context-file-item{display:flex;align-items:center;gap:8px}.context-file-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-color);cursor:pointer;flex-shrink:0}.context-file-name{flex-grow:1;font-size:13px;color:var(--text-color);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .2s}.context-file-name:hover{text-decoration-color:var(--primary-color)}.delete-context-file-btn{background:none;border:none;color:var(--subtle-text-color);font-size:20px;line-height:1;cursor:pointer;padding:0 4px;transition:color .2s;flex-shrink:0}.delete-context-file-btn:hover{color:var(--error-color)}.button-group{display:flex;gap:12px;flex-wrap:wrap}.generate-button,.correct-button,.optimize-button,.verify-button,.annotate-button{flex:1;color:#fff;border:none;border-radius:8px;padding:12px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s,border-color .2s;display:flex;align-items:center;justify-content:center;gap:8px;min-width:0}.generate-button{background-color:var(--primary-color)}.generate-button:hover:not(:disabled){background-color:var(--primary-color-hover)}.correct-button{background-color:#3f3f46}.correct-button:hover:not(:disabled){background-color:#52525b}.optimize-button,.verify-button,.annotate-button{background-color:var(--surface-color);border:1px solid var(--border-color);color:var(--text-color);font-size:14px;font-weight:400}.optimize-button:hover:not(:disabled),.verify-button:hover:not(:disabled),.annotate-button:hover:not(:disabled){background-color:#3a3a3e;border-color:var(--subtle-text-color)}.generate-button:disabled,.correct-button:disabled,.optimize-button:disabled,.verify-button:disabled,.annotate-button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.divider{border-top:1px solid var(--border-color);margin:-4px 0}.manual-controls,.project-controls{display:flex;flex-direction:column;gap:12px}.manual-controls h3,.project-controls h3{font-size:14px;color:var(--subtle-text-color);margin-bottom:8px;width:100%}.manual-controls .button-group,.project-controls .button-group{width:100%}.control-button{flex:1 1 auto;background-color:var(--surface-color);border:1px solid var(--border-color);color:var(--text-color);padding:10px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;min-width:120px}.control-button.icon-button{display:flex;align-items:center;justify-content:center;gap:8px}.control-button:hover:not(:disabled){background-color:#3a3a3e;border-color:var(--subtle-text-color)}.control-button.active{background-color:var(--selected-color);border-color:var(--selected-color);color:#1a1a1a;font-weight:500}.control-button:disabled{opacity:.5;cursor:not-allowed}.project-title{font-size:14px!important;padding:0;color:var(--subtle-text-color)!important}.project-title span{color:var(--text-color);font-family:Roboto Mono,monospace;background-color:var(--background-color);padding:2px 6px;border-radius:4px}.canvas-and-legend-wrapper{flex-grow:1;display:flex;flex-direction:column;min-width:0;height:100%;background-color:var(--background-color)}.canvas-container{flex-grow:1;display:flex;align-items:center;justify-content:center;padding:20px;background-image:radial-gradient(var(--grid-color) 1px,transparent 1px);overflow:hidden;position:relative;min-height:0;transition:background-color .2s,outline-color .2s}.canvas-container.drag-over{outline:2px dashed var(--primary-color);outline-offset:-10px;background-color:#222}.rf-canvas{width:100%;height:100%;overflow:visible}.rf-canvas.dragging{cursor:grabbing}.rf-canvas.panning{cursor:move}.rf-canvas.connection-mode{cursor:crosshair}.block-group{cursor:grab}.block-group.dragging{cursor:grabbing}.block-rect{fill:var(--surface-color);stroke:var(--primary-color);stroke-width:2px;rx:6px;ry:6px;transition:stroke .2s,stroke-width .2s}.block-group.selected .block-rect{stroke:var(--selected-color);stroke-width:3px}.block-text{fill:var(--text-color);font-family:Roboto Mono,monospace;font-weight:500;text-anchor:middle;dominant-baseline:central;-webkit-user-select:none;user-select:none;pointer-events:none}.annotation-wrapper{cursor:move}.annotation-foreign-object{color:var(--subtle-text-color);font-family:Inter,sans-serif;font-style:italic;text-align:center;word-wrap:break-word;overflow-wrap:break-word;line-height:1.3;padding:2px;-webkit-user-select:none;user-select:none;pointer-events:none}.annotation-resize-handle{fill:var(--selected-color);stroke:var(--background-color);stroke-width:2px;opacity:0;transition:opacity .2s}.annotation-wrapper:hover .annotation-resize-handle,.annotation-wrapper.selected .annotation-resize-handle{opacity:1}.resize-handle-se,.resize-handle-sw{cursor:ew-resize}.connection-line{fill:none;stroke:var(--primary-color);stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s,stroke-width .2s}.connection-line:hover{stroke:var(--selected-color);stroke-width:4px;cursor:pointer}.connection-line.selected{stroke:var(--selected-color);stroke-width:4px}.connection-preview-line{fill:none;stroke:var(--selected-color);stroke-width:2px;stroke-dasharray:4 4;pointer-events:none}.port{fill:var(--primary-color);transition:fill .2s,r .2s;cursor:default}.rf-canvas.connection-mode .port{cursor:pointer;r:6}.rf-canvas.connection-mode .port:hover{fill:var(--selected-color)}.port.connection-start{fill:var(--selected-color);r:8}.block-group.selected .port{fill:var(--selected-color)}.net-label-block .block-rect{fill:transparent;stroke:none}.net-label-block .block-text{font-family:Roboto Mono,monospace;font-weight:500;font-style:normal;transition:fill .2s;text-anchor:start}.net-label-block .port{display:none}.port.net-port-highlight{fill:var(--selected-color)!important;r:7;stroke:var(--selected-color);stroke-width:1px}.net-label-block.net-highlight .block-text{fill:var(--selected-color)!important;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}.component-library-panel{width:300px;background-color:var(--surface-color);border-left:1px solid var(--border-color);flex-shrink:0;transition:margin-right .3s ease-in-out;position:relative;display:flex;flex-direction:column;margin-right:0}.component-library-panel.closed{margin-right:-300px}.library-toggle-button{position:absolute;left:-30px;top:20px;width:30px;height:48px;background-color:var(--surface-color);border:1px solid var(--border-color);border-right:none;border-radius:8px 0 0 8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.library-toggle-button .chevron{width:10px;height:10px;border-style:solid;border-color:var(--text-color);border-width:0 2px 2px 0;display:inline-block;padding:3px;transform:rotate(135deg);transition:transform .3s ease-in-out}.component-library-panel:not(.closed) .library-toggle-button .chevron{transform:rotate(-45deg)}.library-content{padding:24px;overflow-y:auto;height:100%}.library-content h2{margin-bottom:20px}.component-category h3,.custom-components-section h3{font-size:14px;color:var(--subtle-text-color);margin-top:16px;margin-bottom:8px;border-bottom:1px solid var(--border-color);padding-bottom:4px}.component-category ul,.custom-component-list{list-style:none}.component-item{display:flex;align-items:center;gap:12px;padding:8px 0;font-size:14px}.component-item[title]:hover{background-color:#ffffff0d;border-radius:4px}.component-item[draggable=true]{cursor:grab}.component-item[draggable=true]:active{cursor:grabbing}.component-abbr{background-color:var(--background-color);padding:4px 8px;border-radius:4px;font-family:Roboto Mono,monospace;font-weight:500;color:var(--primary-color);width:50px;text-align:center;flex-shrink:0}.component-name{color:var(--text-color);flex-grow:1;word-break:break-word}.component-abbr.custom{color:var(--selected-color)}.custom-components-section{margin-top:24px}.library-actions{margin-bottom:16px}.custom-component-form{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.custom-component-form input{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:6px;padding:10px;color:var(--text-color);font-size:14px}.custom-component-form input:focus{outline:none;border-color:var(--primary-color)}.custom-component-form button{background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;padding:10px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.custom-component-form button:hover{background-color:var(--primary-color-hover)}.custom-component-item{position:relative}.delete-component-btn{background:none;border:none;color:var(--subtle-text-color);font-size:24px;line-height:1;cursor:pointer;padding:0 8px;transition:color .2s;flex-shrink:0}.delete-component-btn:hover{color:var(--error-color)}.context-menu{position:fixed;z-index:1000;background-color:#333337;border:1px solid var(--border-color);border-radius:8px;padding:8px;box-shadow:0 4px 12px #0000004d;min-width:180px}.context-menu-item{padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.context-menu-item:hover{background-color:var(--primary-color);color:#fff}.context-menu-item.danger:hover{background-color:var(--danger-color);color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background-color:var(--surface-color);padding:24px;border-radius:12px;border:1px solid var(--border-color);width:100%;max-width:400px;box-shadow:0 5px 15px #00000080;display:flex;flex-direction:column}.modal-content h2{margin-top:0;margin-bottom:12px;font-size:18px}.modal-content p{margin-bottom:20px;font-size:14px;color:var(--subtle-text-color)}.modal-content .form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.modal-content label{font-size:14px;color:var(--subtle-text-color)}.modal-content .checkbox-label{flex-direction:row;align-items:center;gap:12px;cursor:pointer}.modal-content .checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color)}.modal-content .checkbox-label span{color:var(--text-color)}.modal-content input,.modal-content select,.modal-content textarea{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:6px;padding:10px;color:var(--text-color);font-size:14px;font-family:inherit}.modal-content input:focus,.modal-content select:focus,.modal-content textarea:focus{outline:none;border-color:var(--primary-color)}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.modal-actions .button-primary{background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;padding:10px 16px;font-size:14px;cursor:pointer}.modal-actions .button-primary:hover:not(:disabled){background-color:var(--primary-color-hover)}.modal-actions .button-primary:disabled{background-color:var(--border-color);cursor:not-allowed;opacity:.7}.modal-actions .button-secondary{background-color:transparent;border:1px solid var(--border-color);color:var(--text-color);border-radius:6px;padding:10px 16px;font-size:14px;cursor:pointer}.modal-actions .button-secondary:hover{background-color:var(--border-color)}.new-blocks-list{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow-y:auto;padding-right:8px}.new-block-item{display:flex;align-items:center;gap:12px}.new-block-item .component-abbr{width:60px}.new-block-item input{flex-grow:1}.settings-modal{max-width:800px;height:80vh;padding:0}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.settings-header h2{margin:0}.close-button{background:none;border:none;color:var(--subtle-text-color);font-size:24px;cursor:pointer}.settings-tabs{display:flex;padding:0 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.settings-tab{padding:12px 16px;background:none;border:none;color:var(--subtle-text-color);cursor:pointer;font-size:14px;border-bottom:2px solid transparent}.settings-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.settings-content{padding:24px;overflow-y:auto;flex-grow:1}.settings-form .form-group{max-width:500px}.form-group-hint{font-size:12px!important;color:var(--subtle-text-color)!important;margin:4px 0 0!important;line-height:1.4!important}.prompts-form textarea{height:150px;resize:vertical;font-family:Roboto Mono,monospace}.prompt-label-header{display:flex;justify-content:space-between;align-items:center;width:100%}.prompt-label-header .button-secondary{padding:4px 8px;font-size:12px}.library-form .form-group-hint{margin-bottom:20px!important}.library-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.library-form-header .form-group-hint{margin-bottom:0!important}.library-category-group{border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:20px}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.category-name-input{flex-grow:1;background:none;border:none;color:var(--primary-color);font-size:16px;font-weight:500;padding:4px 0;border-bottom:1px solid transparent}.category-name-input:focus{outline:none;border-bottom-color:var(--primary-color)}.library-edit-item{display:flex;align-items:center;gap:12px;margin-bottom:8px}.library-edit-item .abbr-input{width:80px;flex-shrink:0;text-align:center;font-family:Roboto Mono,monospace}.library-edit-item .name-input{flex-grow:1}.library-edit-item .hint-input{flex-grow:2}.library-edit-item input{flex-grow:1}.button-add-item,.button-add-category{background-color:transparent;border:1px dashed var(--border-color);color:var(--subtle-text-color);padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;margin-top:12px}.button-add-item:hover,.button-add-category:hover{border-color:var(--primary-color);color:var(--primary-color)}.button-add-category{width:100%;padding:12px}.help-modal{max-width:800px;height:80vh;padding:0}.help-section{margin-bottom:24px}.help-section:last-child{margin-bottom:0}.help-section h3{font-size:18px;color:var(--primary-color);margin-bottom:12px;border-bottom:1px solid var(--border-color);padding-bottom:8px}.help-section p,.help-section li{font-size:14px;line-height:1.6;color:var(--text-color)}.help-section ul,.help-section ol{margin-top:12px;margin-left:20px;padding-left:10px}.help-section li{margin-bottom:8px}.help-section code{background-color:var(--background-color);padding:2px 6px;border-radius:4px;font-family:Roboto Mono,monospace;color:var(--selected-color);font-size:13px}.file-viewer-modal{max-width:800px;height:80vh;padding:0}.file-content-display{background-color:var(--background-color);padding:16px;border-radius:8px;border:1px solid var(--border-color);font-family:Roboto Mono,monospace;font-size:13px;white-space:pre-wrap;word-break:break-all;max-height:calc(80vh - 150px);overflow-y:auto}.log-panel{background-color:var(--surface-color);border-top:1px solid var(--border-color);flex-shrink:0;display:flex;flex-direction:column;transition:height .3s ease-in-out}.log-panel-resizer{width:100%;height:5px;background-color:transparent;cursor:row-resize;position:absolute;top:-2px;left:0;z-index:10}.log-panel-header{display:flex;justify-content:space-between;align-items:center;padding:0 16px;height:40px;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0}.log-panel-header h3{font-size:14px;font-weight:500;color:var(--subtle-text-color)}.log-panel-header .chevron{width:10px;height:10px;border-style:solid;border-color:var(--subtle-text-color);border-width:0 2px 2px 0;transform:rotate(45deg);transition:transform .3s ease-in-out}.log-panel.open .log-panel-header .chevron{transform:rotate(-135deg)}.log-content{flex-grow:1;overflow-y:auto;padding:0 16px 16px;font-family:Roboto Mono,monospace;font-size:13px;background-color:var(--background-color)}.log-entry{padding:4px 0;display:flex;gap:12px;white-space:pre-wrap;border-bottom:1px solid var(--border-color)}.log-timestamp{color:var(--subtle-text-color)}.log-message{color:var(--text-color)}.log-entry-error .log-message{color:var(--error-color)}.log-entry-success .log-message{color:var(--success-color)}.log-details{margin-top:8px;padding:8px;background-color:#0003;border-radius:4px;color:var(--subtle-text-color);white-space:pre-wrap;word-break:break-all}.component-legend,.operation-principle{flex-shrink:0;background-color:var(--surface-color);border-top:1px solid var(--border-color)}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:12px 16px}.collapsible-header h4{font-size:14px;color:var(--subtle-text-color);margin:0}.collapsible-header .chevron{width:10px;height:10px;border-style:solid;border-color:var(--subtle-text-color);border-width:0 2px 2px 0;transform:rotate(45deg);transition:transform .3s ease-in-out}.component-legend.open .collapsible-header .chevron,.operation-principle.open .collapsible-header .chevron{transform:rotate(-135deg)}.collapsible-content{max-height:0;overflow-y:auto;transition:max-height .3s ease-out,padding-bottom .3s ease-out;padding:0 16px}.component-legend.open .collapsible-content{max-height:250px;padding-bottom:16px}.operation-principle.open .collapsible-content{max-height:400px;padding-bottom:16px}.operation-principle .collapsible-content h2,.operation-principle .collapsible-content h3,.operation-principle .collapsible-content h4{margin-top:1em;margin-bottom:.5em;color:var(--text-color)}.operation-principle .collapsible-content h3{font-size:1.1em;color:var(--primary-color);border-bottom:1px solid var(--border-color);padding-bottom:4px}.operation-principle .collapsible-content p{font-size:14px;line-height:1.6;margin-bottom:1em;word-wrap:break-word}.operation-principle .collapsible-content ul,.operation-principle .collapsible-content ol{margin-left:20px;margin-bottom:1em;padding-left:10px}.operation-principle .collapsible-content li{margin-bottom:.5em;line-height:1.5}.operation-principle .collapsible-content strong{color:var(--selected-color);font-weight:500}.operation-principle .collapsible-content em{color:var(--primary-color);font-style:italic}.component-legend ul{list-style:none;margin-bottom:16px;font-size:14px;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:4px 16px}.component-legend li{padding:2px 0;display:flex}.component-legend li strong{flex-shrink:0;width:60px;font-family:Roboto Mono,monospace;color:var(--primary-color)}.component-legend .copy-button,.operation-principle .copy-button{width:100%;max-width:300px;padding:8px;margin-top:1em}
