:root{--font-primary: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-monospace: "Monaco", "Menlo", "Courier New", monospace;--font-icons: "Material Icons Outlined";--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f5;--bg-hover: #f0f0f0;--bg-input: #f8f9fa;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #999999;--text-inverse: #ffffff;--border-primary: #dddddd;--border-secondary: #eeeeee;--border-hover: #aaaaaa;--brand-primary-solid: rgb(46, 125, 50);--brand-secondary: #2c3e50;--brand-tertiary: #34495e;--brand-primary-05: rgba(46, 125, 50, .05);--brand-primary-10: rgba(46, 125, 50, .1);--brand-primary-20: rgba(46, 125, 50, .2);--brand-primary-30: rgba(46, 125, 50, .3);--brand-primary-50: rgba(46, 125, 50, .5);--brand-primary-70: rgba(46, 125, 50, .7);--brand-primary: var(--brand-primary-70);--brand-primary-hover: var(--brand-primary-solid);--status-error: #d32f2f;--status-error-bg: #ffebee;--status-success: #51cf66;--status-success-bg: rgba(81, 207, 102, .1);--status-warning: #ffc107;--status-warning-bg: rgba(255, 193, 7, .1);--status-info: #007bff;--status-info-bg: rgba(0, 123, 255, .1);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 12px rgba(0, 0, 0, .15);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .3);--welcome-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #242424;--bg-tertiary: #2a2a2a;--bg-hover: #333333;--bg-input: #2d2d2d;--text-primary: #f0f0f0;--text-secondary: #c8c8c8;--text-tertiary: #999999;--text-inverse: #ffffff;--border-primary: #404040;--border-secondary: #333333;--border-hover: #606060;--brand-primary-solid: rgb(46, 125, 50);--brand-secondary: #1a2332;--brand-tertiary: #252e3a;--brand-primary-05: rgba(46, 125, 50, .05);--brand-primary-10: rgba(46, 125, 50, .1);--brand-primary-20: rgba(46, 125, 50, .2);--brand-primary-30: rgba(46, 125, 50, .3);--brand-primary-50: rgba(46, 125, 50, .5);--brand-primary-70: rgba(46, 125, 50, .7);--brand-primary: var(--brand-primary-50);--brand-primary-hover: var(--brand-primary-solid);--status-error: #f44336;--status-error-bg: #3d1f1f;--status-success: #66bb6a;--status-success-bg: rgba(102, 187, 106, .1);--status-warning: #ffb300;--status-warning-bg: rgba(255, 179, 0, .1);--status-info: #29b6f6;--status-info-bg: rgba(41, 182, 246, .1);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .5);--welcome-gradient: linear-gradient(135deg, #4a5699 0%, #5c3a6e 100%)}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);font-size:14px;line-height:1.6;color:var(--text-primary);background:var(--bg-tertiary)}.hidden{display:none!important}.empty-state{color:var(--text-tertiary);text-align:center;padding:40px 20px;font-style:italic}.loading-text{color:var(--text-secondary);text-align:center;padding:20px}body.no-data .category-sidebar,body.no-data #category-list,body.no-data #chat-toggle-btn,body.no-data #migration-toggle-btn,body.no-data #world-info,body.no-data #export-json-btn,body.no-data .sidebar-header h2,body.no-data #element-detail{display:none!important}body.has-data.mode-online .category-sidebar,body.has-data.mode-local .category-sidebar,body.has-data.mode-online #chat-toggle-btn,body.has-data.mode-local #chat-toggle-btn,body.has-data.mode-online #migration-toggle-btn,body.has-data.mode-local #migration-toggle-btn,body.has-data.mode-online #world-info,body.has-data.mode-local #world-info{display:block!important;visibility:visible!important}body.has-data #export-json-btn{display:inline-block!important}body.no-data #export-json-btn{display:none!important}.error-text{color:var(--status-error);text-align:center;padding:20px}.error-message{color:var(--status-error);padding:10px;margin-top:10px;background:var(--status-error-bg);border-radius:4px;font-size:13px}.auth-bar{background:var(--brand-secondary);color:var(--text-inverse);padding:12px 20px;box-shadow:var(--shadow-sm);height:68px;box-sizing:border-box;display:flex;align-items:center;gap:20px}.auth-bar-content{display:flex;justify-content:space-between;align-items:center;flex:1;gap:20px}.world-info-far-left{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:210px;flex-shrink:0}.auth-inputs-left,.auth-inputs-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.auth-input{padding:6px 10px;font-size:12px;background:var(--brand-tertiary);border:1px solid var(--brand-tertiary);color:var(--text-inverse);border-radius:4px;transition:all .2s}.auth-input::placeholder{color:#fff9}.auth-input:focus{outline:none;border-color:var(--brand-primary);background:var(--brand-tertiary)}.auth-input{width:120px}.auth-input-pin{width:60px}.auth-status{font-size:12px;margin-left:10px}.auth-status.error{color:var(--status-error)}.auth-status.success{color:var(--status-success)}.world-name{font-size:14px;font-weight:700;color:var(--text-inverse);opacity:1;visibility:visible;transition:opacity .2s ease}.world-name.hidden{opacity:0;visibility:hidden}.world-api-key{font-size:11px;color:var(--text-tertiary);font-family:var(--font-monospace);background:#ffffff1a;padding:1px 4px;border-radius:2px;opacity:1;visibility:visible;transition:all .2s ease}.world-api-key.local-mode{background:#80808033;color:var(--text-secondary)}.world-api-key.online-mode{background:#3b82f680;color:var(--text-inverse)}.world-api-key.placeholder-key{background:transparent;color:var(--text-muted)}.world-api-key.hidden{opacity:0;visibility:hidden}.auth-bar-actions{display:flex;gap:10px}#favorite-indicator{position:relative;background:transparent;border:none;color:#ffffffb3;padding:6px;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;margin-right:4px}#favorite-indicator:hover{background:#ffffff1a;color:var(--text-inverse)}#favorite-indicator .favorite-element-icon{font-size:20px;color:gold}.btn{padding:6px 12px;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s;text-align:center}.btn-secondary{background:var(--bg-hover);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-primary)}.btn-danger{background:var(--status-error);color:var(--text-inverse)}.btn-danger:hover{background:var(--status-error)}.btn-small{padding:6px 12px;font-size:13px}.btn-large{padding:12px 24px;font-size:14px}.app-container{display:flex;flex-direction:column;height:100vh}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--welcome-gradient)}.welcome-content{background:var(--bg-primary);border-radius:8px;padding:30px 40px;max-width:400px;width:100%;box-shadow:var(--shadow-md);text-align:center}.welcome-content h2{color:var(--text-primary);font-size:18px;font-weight:500;margin-bottom:15px}.welcome-content p{color:var(--text-secondary);font-size:14px;margin-bottom:10px;line-height:1.5}.welcome-link{margin-top:15px}.welcome-link a{color:var(--brand-primary);text-decoration:none;font-size:14px}.welcome-link a:hover{text-decoration:underline}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:250px;background:var(--bg-primary);border-right:1px solid var(--border-primary);padding:20px;overflow-y:auto}.sidebar h2{font-size:16px;color:var(--text-primary);margin-bottom:15px;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.category-list{display:flex;flex-direction:column;gap:4px}.category-item{display:flex;align-items:center;padding:8px 12px;border-radius:4px;cursor:pointer;transition:background .2s}.category-item:hover{background:var(--bg-tertiary)}.category-item.active{background:var(--brand-primary-10);color:var(--brand-primary)}.category-item.disabled{pointer-events:none;opacity:.5;cursor:not-allowed}.category-icon{width:24px;font-size:18px;margin-right:10px;font-family:Material Icons Outlined;font-weight:400;font-style:normal;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.category-name{flex:1;font-size:14px}.category-count{font-size:12px;color:var(--text-tertiary);background:var(--bg-hover);padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.btn-primary{padding:6px 16px;font-size:12px;background:var(--brand-primary);color:var(--text-inverse);border:none;border-radius:4px;cursor:pointer;transition:all .2s;min-width:100px}.btn-primary:hover:not(:disabled){background:var(--brand-primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-validate{padding:6px 16px;font-size:12px;background:var(--brand-primary);color:var(--text-inverse);border:none;border-radius:4px;cursor:pointer;transition:all .2s;min-width:100px}.btn-validate:hover:not(:disabled){background:var(--brand-primary-hover)}.btn-validate:disabled{opacity:.5;cursor:not-allowed}.btn-validate.validated{background:var(--brand-primary-30)!important;color:var(--text-inverse)!important}.btn-icon{background:transparent;border:none;color:#ffffffb3;cursor:pointer;padding:6px;border-radius:4px;transition:all .2s}.btn-icon:hover{background:#ffffff1a;color:var(--text-inverse)}.icon{width:20px;height:20px}.modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--bg-primary);border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-secondary)}.modal-header h2{font-size:18px;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:24px;color:var(--text-tertiary);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:var(--text-primary);font-size:13px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid var(--border-primary);border-radius:4px;font-size:14px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--brand-primary)}.form-group textarea{resize:vertical;min-height:80px}.form-separator{margin:20px 0 15px;padding-top:15px;border-top:1px solid var(--border-primary)}.form-separator h4{margin:0 0 10px;color:var(--text-secondary);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.form-help-text{display:block;margin-top:4px;font-size:12px;color:var(--text-tertiary);font-style:italic}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:30px;padding-top:20px;border-top:1px solid var(--border-secondary)}.modal-content button,.modal-content .btn{min-height:34px}.loading-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:2000}.spinner{width:40px;height:40px;border:4px solid var(--bg-tertiary);border-top:4px solid var(--brand-primary);border-radius:50%;animation:spin 1s linear infinite}.element-list-container{flex:1;background:var(--bg-secondary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;min-width:300px}.list-header{background:var(--bg-primary);padding:15px 20px;border-bottom:1px solid var(--border-primary);height:102px;box-sizing:border-box}.list-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.list-header h2{font-size:16px;color:var(--text-primary);margin:0}.btn-add-element{background:var(--brand-primary);color:var(--text-inverse);border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.btn-add-element:hover{background:var(--brand-primary-hover);transform:scale(1.1)}.btn-add-element .material-icons-outlined{font-size:18px}.search-input{width:100%;padding:8px 12px;border:1px solid var(--border-primary);border-radius:4px;font-size:14px;background:var(--bg-primary);color:var(--text-primary)}.search-input::placeholder{color:var(--text-tertiary)}.search-input:focus{outline:none;border-color:var(--brand-primary);background:var(--bg-primary)}.element-list{flex:1;overflow-y:auto;padding:10px}.element-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .2s}.element-card:hover{border-color:var(--brand-primary);box-shadow:var(--shadow-sm)}.element-card.selected{border-color:var(--brand-primary);background:var(--brand-primary-05)}.element-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}.element-icon{font-size:20px;line-height:1;font-family:Material Icons Outlined;font-weight:400;font-style:normal;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.element-info{flex:1}.element-name{font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.element-supertype{font-size:12px;color:var(--text-secondary);background:var(--bg-hover);padding:2px 6px;border-radius:3px;display:inline-block;margin-top:4px}.element-description{font-size:13px;color:var(--text-secondary);margin:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.element-detail-container{flex:1;min-width:300px;background:var(--bg-primary);overflow-y:auto}.element-detail{padding:20px}#welcome-element-detail{flex:1;min-width:300px;background:var(--bg-primary);overflow-y:auto}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--bg-hover)}.detail-header h2{font-size:20px;color:var(--text-primary)}.detail-actions{display:flex;gap:10px}.detail-section{margin-bottom:30px}.detail-section h3{font-size:14px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:15px;font-weight:600}.detail-table{width:100%;border-collapse:collapse}.detail-table tr{border-bottom:1px solid var(--bg-hover)}.detail-table td{padding:10px 0;vertical-align:top}.field-label{font-weight:500;color:var(--text-secondary);width:150px;font-size:13px}.field-value{color:var(--text-primary);font-size:14px}.field-value pre{background:var(--bg-tertiary);padding:10px;border-radius:4px;font-size:12px;overflow-x:auto}.field-value code{background:var(--bg-tertiary);padding:2px 6px;border-radius:3px;font-family:var(--font-monospace);font-size:13px}.field-value a{color:var(--brand-primary);text-decoration:none}.field-value a:hover{text-decoration:underline}.inline-editor-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:2px solid var(--border-secondary);background:var(--bg-primary);position:sticky;top:0;z-index:100;margin:-20px -20px 20px;box-shadow:var(--shadow-sm)}.inline-editor-header h2{margin:0;font-size:24px;color:var(--text-primary);flex:1;display:flex;align-items:center;gap:12px}.inline-editor-header h2 .element-icon{font-size:26px}.header-actions{display:flex;align-items:center;gap:12px}.save-status{display:flex;align-items:center;gap:8px;padding:5px 12px;background:var(--bg-tertiary);border-radius:20px;font-size:13px;transition:all .3s ease}.delete-btn-icon{background:transparent;color:var(--text-tertiary);border:1px solid var(--border-primary);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.delete-btn-icon:hover{background:#ef44441a;color:var(--status-error);border-color:#ef44444d}.delete-btn-icon:active{transform:scale(.95)}.delete-btn-icon svg{width:18px;height:18px}.favorite-btn-icon{background:transparent;color:var(--text-tertiary);border:1px solid var(--border-primary);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.favorite-btn-icon:hover,.favorite-btn-icon.favorited{background:#ffd7001a;color:gold;border-color:#ffd7004d}.favorite-btn-icon.favorited:hover{background:#ffd70026}.favorite-btn-icon:active{transform:scale(.95)}.favorite-btn-icon .material-icons-outlined{font-size:18px}.hide-empty-btn-icon{background:transparent;color:var(--text-tertiary);border:1px solid var(--border-primary);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.hide-empty-btn-icon:hover{background:var(--brand-primary-10);color:var(--brand-primary);border-color:var(--brand-primary)}.hide-empty-btn-icon:active{transform:scale(.95)}.hide-empty-btn-icon .material-icons-outlined{font-size:18px}.inline-editor-fields.hide-empty .compact-field[data-is-empty=true]{display:none}.save-status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brand-primary);animation:none}.save-status.typing{background:#ffc10733}.save-status.typing:before{background:var(--status-warning)}.save-status.saving{background:#007bff33}.save-status.saving:before{background:var(--status-info);animation:pulse 1s infinite}.save-status.saved{background:var(--brand-primary-20)}.save-status.saved:before{background:var(--brand-primary)}.save-status.error{background:#dc354533}.save-status.error:before{background:var(--status-error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.field-section{margin-bottom:30px}.field-section h3{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:15px;text-transform:uppercase;letter-spacing:.5px}.fields-container{margin:20px 0}.compact-field{display:flex;align-items:flex-start;margin-bottom:12px;padding:8px;border:1px solid transparent;border-radius:4px;transition:all .2s ease}.compact-field:hover{background:var(--bg-input);border-color:var(--border-secondary)}.compact-field.editing{background:var(--brand-primary-05);border-color:var(--brand-primary)}.compact-field.dirty{border-color:var(--status-warning)}.compact-label{min-width:150px;font-size:13px;font-weight:600;color:var(--text-secondary);padding-top:8px}.compact-value{flex:1;display:flex;align-items:center;gap:8px}.compact-value .inline-input,.compact-value .inline-textarea{flex:1}.relationship-display{flex:1;padding:6px 10px;background:var(--bg-input);border:1px solid var(--border-primary);border-radius:4px;font-size:14px}.relationship-count{color:var(--brand-primary);font-weight:500}.relationship-id{font-family:var(--font-monospace);font-size:12px;color:var(--text-secondary)}.relationship-empty{color:var(--text-tertiary);font-style:italic}.relationship-field{display:flex;flex-wrap:wrap;align-items:center;gap:8px;min-height:36px}.relationship-tags{display:flex;flex-wrap:wrap;gap:6px;flex:1}.element-tag{display:inline-flex;align-items:center;background:#2196f31a;border:1px solid rgba(33,150,243,.3);border-radius:16px;padding:4px 8px 4px 12px;font-size:13px;gap:6px;max-width:200px}.element-tag.tag-invalid{background:var(--status-error-bg);border-color:var(--status-error)}.element-tag.tag-broken{background:var(--status-warning-bg);border-color:var(--status-warning);opacity:.7}.tag-broken .tag-name{color:var(--status-warning);font-style:italic}.tag-broken .tag-icon{color:var(--status-warning)}.tag-name{color:var(--status-info);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag-name:hover{text-decoration:underline}.tag-invalid .tag-name{color:var(--status-error);cursor:default}.tag-invalid .tag-name:hover{text-decoration:none}.tag-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:18px;line-height:1;padding:0;border-radius:50%}.tag-remove:hover{background:var(--bg-hover);color:var(--status-error)}.btn-add-relationship{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px dashed var(--text-tertiary);border-radius:14px;cursor:pointer;color:var(--text-secondary);transition:all .2s}.btn-add-relationship:hover{background:var(--bg-tertiary);border-color:var(--status-info);color:var(--status-info)}.btn-add-relationship .material-icons-outlined{font-size:18px}.btn-add-relationship.disabled{background:transparent;border:1px dashed var(--text-muted);color:var(--text-muted);cursor:pointer;opacity:.6}.btn-add-relationship.disabled:hover{background:var(--bg-tertiary);border-color:var(--text-secondary);color:var(--text-secondary);opacity:.8}.btn-add-relationship.checking{border:1px dashed var(--text-secondary);color:var(--text-secondary);cursor:default;opacity:.8}.btn-add-relationship.checking .material-icons-outlined{color:var(--text-secondary)}.relationship-selector{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:var(--shadow-md);width:300px;max-height:400px;display:flex;flex-direction:column;overflow:hidden}.selector-search{padding:10px;border:none;border-bottom:1px solid var(--border-secondary);font-size:14px;outline:none;background:var(--bg-primary);color:var(--text-primary)}.selector-search:focus{background:var(--bg-tertiary)}.selector-results{flex:1;overflow-y:auto;max-height:350px}.selector-loading,.selector-empty,.selector-error{padding:20px;text-align:center;color:var(--text-tertiary);font-style:italic}.selector-error{color:var(--status-error)}.selector-item{padding:10px;cursor:pointer;border-bottom:1px solid var(--bg-hover);display:flex;align-items:center;gap:10px;transition:background .1s}.selector-item:hover{background:var(--bg-tertiary)}.selector-item.selected{background:var(--brand-primary-10)}.selector-item.selected:hover{background:var(--brand-primary-20)}.selector-icon{font-size:18px;color:var(--text-secondary)}.selector-name{flex:1;font-weight:500}.selector-desc{font-size:11px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}.relationship-modal{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.relationship-modal-content{background:var(--bg-primary);border-radius:8px;width:90%;max-width:500px;max-height:70vh;display:flex;flex-direction:column}.relationship-modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid var(--border-secondary)}.relationship-modal-header h3{margin:0;font-size:18px}.modal-close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-tertiary)}.relationship-modal-body{flex:1;overflow-y:auto;padding:20px}.relationship-search{width:100%;padding:8px 12px;border:1px solid var(--border-primary);border-radius:4px;margin-bottom:15px;font-size:14px;background:var(--bg-primary);color:var(--text-primary)}.relationship-list{max-height:300px;overflow-y:auto}.relationship-item{display:flex;align-items:center;padding:8px;border-radius:4px;transition:background .2s}.relationship-item:hover{background:var(--bg-input)}.relationship-item input[type=checkbox],.relationship-item input[type=radio]{margin-right:10px}.relationship-item label{flex:1;cursor:pointer;font-size:14px}.relationship-item small{display:block;color:var(--text-tertiary);font-size:12px;margin-top:2px}.relationship-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:15px 20px;border-top:1px solid var(--border-secondary)}.editable-field{margin-bottom:15px;padding:10px;border:1px solid transparent;border-radius:6px;transition:all .2s ease}.editable-field:hover{background:var(--bg-input);border-color:var(--border-secondary)}.editable-field.editing{background:var(--brand-primary-05);border-color:var(--brand-primary);box-shadow:0 0 0 3px var(--brand-primary-10)}.editable-field.dirty{border-color:var(--status-warning)}.editable-field label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}.inline-input,.inline-textarea{width:100%;padding:8px 10px;border:1px solid var(--border-primary);border-radius:4px;font-size:14px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.inline-input:hover,.inline-textarea:hover{border-color:var(--border-hover);cursor:text}.inline-input:focus,.inline-textarea:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 2px var(--brand-primary-10)}.inline-textarea{min-height:60px;resize:vertical}.inline-textarea-small{min-height:32px;resize:vertical;overflow-y:hidden}.inline-input.number-input{resize:none!important;height:auto;min-height:auto}input[type=number].inline-input{resize:none!important;overflow:visible;white-space:nowrap}.json-input{font-family:var(--font-monospace);font-size:13px}.uuid-input{font-family:var(--font-monospace);font-size:12px}.checkbox-wrapper{display:flex;align-items:center;gap:10px}.inline-checkbox{width:20px;height:20px;cursor:pointer}.checkbox-label{font-size:14px;color:var(--text-primary)}.field-help{display:block;margin-top:5px;font-size:12px;color:var(--text-tertiary);font-style:italic}.metadata-section{background:var(--bg-input);padding:15px;border-radius:6px;margin-top:30px}.metadata-field{display:flex;gap:10px;margin-bottom:8px;font-size:13px}.metadata-field label{font-weight:600;color:var(--text-secondary);min-width:80px}.metadata-field code{font-family:var(--font-monospace);font-size:12px;background:var(--bg-primary);padding:2px 6px;border-radius:3px;border:1px solid var(--border-primary)}@media (max-width: 768px){.main-content{flex-direction:column}.sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--border-primary)}.element-list-container{min-width:auto;border-right:none;flex:1;min-height:300px}.element-detail-container{min-height:300px}.category-item,.element-card{padding:12px;min-height:48px}.btn-add-element{width:36px;height:36px}.modal{padding:10px}.modal-content{margin:0;max-height:85vh}}.import-tabs{display:flex;gap:10px;margin-top:5px}.import-tab{flex:1;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:4px;cursor:pointer;transition:all .2s;font-size:14px}.import-tab:hover{background:var(--bg-hover)}.import-tab.active{background:var(--brand-primary);color:var(--text-inverse);border-color:var(--brand-primary)}.import-tab-content{margin-top:15px}.import-tab-content.hidden{display:none}#import-paste{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:4px;padding:8px;resize:vertical;min-height:150px}#import-paste:focus{outline:none;border-color:var(--brand-primary)}.import-export-controls{display:flex;align-items:center;gap:10px;margin-left:20px}.auto-save-toggle{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 8px;border-radius:4px;transition:background .2s}.auto-save-toggle:hover{background:var(--bg-hover)}.auto-save-toggle input[type=checkbox]{margin-right:5px;cursor:pointer}.auto-save-toggle span{font-size:16px;color:var(--status-warning)}.auto-save-toggle input:checked+span{color:var(--status-success)}.modal.compact .modal-content,.modal-content.compact{max-width:500px;width:90%}.preview{margin:10px 0;padding:10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:4px;max-height:150px;overflow-y:auto;font-size:12px;font-family:var(--font-monospace);color:var(--text-secondary)}.progress-bar{height:24px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:4px;overflow:hidden;margin:10px 0;position:relative}.progress-fill{height:100%;background:var(--brand-primary);transition:width .3s ease;display:flex;align-items:center;justify-content:center;color:var(--text-inverse);font-size:12px;font-weight:600;min-width:40px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:15px;border-top:1px solid var(--border-primary);margin-top:15px}input[type=file]{padding:8px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-input);color:var(--text-primary);font-size:14px;cursor:pointer}input[type=file]:hover{border-color:var(--border-hover)}#import-mode{padding:8px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-input);color:var(--text-primary);font-size:14px;cursor:pointer}#import-mode:hover{border-color:var(--border-hover)}#import-mode:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 2px var(--brand-primary-10)}.help-section{margin-bottom:25px}.help-section:last-child{margin-bottom:0}.help-section h3{color:var(--text-primary);font-size:16px;font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-primary)}.help-section ul,.help-section ol{margin:0;padding-left:20px;line-height:1.8}.help-section li{margin-bottom:8px;color:var(--text-secondary)}.help-section li strong{color:var(--text-primary);font-weight:500}.help-section p{line-height:1.6;color:var(--text-secondary);margin:10px 0}.help-section a{color:var(--brand-primary);text-decoration:none}.help-section a:hover{text-decoration:underline}.help-section kbd{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:3px;padding:2px 6px;font-family:var(--font-monospace);font-size:12px;color:var(--text-primary);box-shadow:0 1px 2px #0000001a}.import-dialog .modal-content{max-width:500px;width:90vw}.import-section{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border-primary)}.import-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.import-section h3{margin:0 0 15px;color:var(--text-primary);font-size:16px}.import-section .file-input{display:none}.import-section .btn-small{padding:8px 16px;font-size:14px;border-radius:4px}.import-section textarea{width:100%;height:205px;padding:12px;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-input);color:var(--text-primary);font-family:var(--font-monospace);font-size:13px;resize:vertical}.paste-actions{display:flex;gap:10px;margin-top:10px}.import-warning-text{margin-top:15px;padding:0;font-size:12px;color:var(--text-tertiary);text-align:center}.import-status{margin-top:15px;padding:10px;border-radius:6px;font-weight:500}.import-status.info{background:var(--status-info-bg);color:var(--status-info);border:1px solid var(--status-info)}.import-status.success{background:var(--status-success-bg);color:var(--status-success);border:1px solid var(--status-success)}.import-status.error{background:var(--status-error-bg);color:var(--status-error);border:1px solid var(--status-error)}.help-text{font-size:13px;color:var(--text-tertiary);margin-top:8px;font-style:italic}.help-text a{color:var(--brand-primary);text-decoration:none}.help-text a:hover{text-decoration:underline}.json-validation-status{margin-top:8px;padding:8px 12px;border-radius:4px;font-size:13px;font-weight:500;border-left:3px solid transparent}.json-validation-status.success{background:var(--status-success-bg);color:var(--status-success);border-left-color:var(--status-success)}.json-validation-status.error{background:var(--status-error-bg);color:var(--status-error);border-left-color:var(--status-error)}.import-section input[type=file]:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-tertiary)}.import-section textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-tertiary)}.paste-actions button:disabled{opacity:.6;cursor:not-allowed;background:var(--border-primary)}.paste-actions button.loading{background:var(--brand-primary);color:var(--text-inverse);opacity:.8}.modal-close:disabled{opacity:.5;cursor:not-allowed}.sidebar-header{display:flex;align-items:center;justify-content:flex-end;margin-bottom:1.5rem}.sidebar-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.btn-chat-toggle{background:none;border:1px solid var(--border-primary);border-radius:6px;padding:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.btn-chat-toggle:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.btn-chat-toggle:active{transform:scale(.95)}.btn-chat-toggle .material-icons-outlined{font-size:18px}.btn-chat-toggle.waiting-response{background:#ffc10726;border-color:#ffc10766;color:#ffc107;animation:chat-pulse 2s infinite}@keyframes chat-pulse{0%,to{opacity:1;box-shadow:0 0 #ffc10766}50%{opacity:.8;box-shadow:0 0 0 4px #ffc1071a}}.chat-interface{display:flex;flex-direction:column;height:100%;max-height:calc(100vh - 100px);background:var(--bg-primary)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1rem .5rem;border-bottom:1px solid var(--border-secondary);flex-wrap:wrap;gap:.5rem}.chat-header h2{margin:0;font-size:1.2rem;color:var(--text-primary)}.auth-mode-container{display:flex;flex-direction:column;gap:.75rem;flex:1}.auth-mode-toggle{display:flex;gap:.5rem;align-items:center}.mode-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .8rem;border:1px solid var(--border-secondary);background:var(--bg-secondary);color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:all .2s;font-size:.85rem}.mode-btn .material-icons-outlined{font-size:16px}.mode-btn:hover{background:var(--bg-hover);border-color:var(--border-hover)}.mode-btn.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.token-balance-display{display:flex;flex-direction:column;gap:.25rem}.token-bar{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;border:1px solid var(--border-secondary)}.token-fill{height:100%;background:var(--accent-color);transition:width .3s ease,background .3s ease}.token-fill.low-tokens{background:#f44336}.token-text{font-size:.75rem;color:var(--text-secondary)}.chat-controls{display:flex;gap:.5rem}.btn-clear,.btn-close{background:none;border:1px solid var(--border-primary);border-radius:6px;padding:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.btn-clear:hover,.btn-close:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.btn-clear .material-icons-outlined,.btn-close .material-icons-outlined{font-size:18px}.btn-close:hover{color:var(--status-error)}.chat-setup-notice{display:flex;align-items:flex-start;gap:.75rem;margin:1rem;padding:1rem;background:var(--status-info);color:var(--text-inverse);border-radius:8px;font-size:.9rem;line-height:1.4}.chat-setup-notice .material-icons-outlined{font-size:20px;flex-shrink:0}.chat-messages{flex:1;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth}.chat-welcome{text-align:center;color:var(--text-secondary);padding:2rem 1rem}.chat-welcome p{margin:.5rem 0}.chat-welcome p:first-child{font-size:1.1rem;margin-bottom:1rem}.chat-message{display:flex;flex-direction:column;max-width:80%}.chat-message.user{align-self:flex-end;align-items:flex-end}.chat-message.assistant,.chat-message.operator{align-self:flex-start;align-items:flex-start}.message-content{padding:.75rem 1rem;border-radius:12px;margin-bottom:.25rem;word-wrap:break-word;line-height:1.4}.chat-message.user .message-content{background:var(--brand-primary-30)!important;color:var(--text-primary)!important;border-bottom-right-radius:4px}.chat-message.assistant .message-content,.chat-message.operator .message-content{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-secondary);border-bottom-left-radius:4px}.message-timestamp{font-size:.75rem;color:var(--text-tertiary);padding:0 .5rem;display:flex;align-items:center;gap:.25rem}.chat-message.user .message-timestamp{justify-content:flex-end;flex-direction:row-reverse}.chat-message.assistant .message-timestamp,.chat-message.operator .message-timestamp{justify-content:flex-start}.copy-message-btn{background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:2px;border-radius:3px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:all .2s ease}.copy-message-btn:hover{opacity:1;background:var(--bg-hover);color:var(--text-secondary)}.copy-message-btn:active{transform:scale(.9)}.copy-message-btn svg{width:12px;height:12px}.copy-message-btn.copied{color:var(--status-success)!important;background:var(--status-success-bg)!important;opacity:1!important}@keyframes copy-flash{0%{background:var(--status-success-bg);color:var(--status-success)}to{background:none;color:var(--text-tertiary)}}.chat-message.typing .message-content{padding:1rem}.typing-dots{display:flex;gap:4px;align-items:center}.typing-dots span{width:6px;height:6px;background:var(--text-secondary);border-radius:50%;animation:typing-bounce 1.4s ease-in-out infinite}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}.typing-dots span:nth-child(3){animation-delay:0s}@keyframes typing-bounce{0%,80%,to{transform:scale(.8);opacity:.6}40%{transform:scale(1);opacity:1}}.chat-input-area{padding:1rem;border-top:1px solid var(--border-secondary);background:var(--bg-secondary)}.chat-context-options{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.context-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none;line-height:1.4}.context-option input[type=checkbox],.context-option input[type=radio]{width:16px;height:16px;margin:0;accent-color:var(--brand-primary)}.context-option input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.context-option input[type=checkbox]:disabled+span{opacity:.5;cursor:not-allowed}.chat-input-container{display:flex;gap:.5rem;align-items:flex-end}#chat-input{flex:1;border:1px solid var(--border-primary);border-radius:20px;padding:.75rem 1rem;font-size:.95rem;background:var(--bg-primary);color:var(--text-primary);resize:none;outline:none;transition:border-color .2s ease;min-height:20px;max-height:120px;font-family:inherit;line-height:1.4;overflow-y:hidden}#chat-input:focus{border-color:var(--brand-primary)}#chat-input:disabled{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.btn-send{background:var(--brand-primary-30)!important;color:var(--text-primary)!important;border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;color:var(--text-inverse);transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-send:hover:not(:disabled){background:var(--brand-primary-50)!important;transform:scale(1.05)}.btn-send:active:not(:disabled){transform:scale(.95)}.btn-send:disabled{background:var(--text-tertiary);cursor:not-allowed;opacity:.6}.chat-message.setup-message .message-content{background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-hover));color:var(--text-inverse);border:none;border-radius:12px}.chat-message.setup-message .message-content a{color:var(--text-inverse);text-decoration:underline}.chat-context-bar{display:flex;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-secondary);margin-bottom:.75rem}.btn-context-toggle{display:flex;align-items:center;gap:.5rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s ease}.btn-context-toggle:hover{background:var(--brand-primary);color:var(--text-inverse);border-color:var(--brand-primary)}.loading-spinner{display:inline-block;animation:spin 1s linear infinite;margin-right:4px;color:var(--brand-primary)}.full-data-spinner{margin-right:0!important;animation:spin 1s linear infinite!important;transform-origin:center center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.chat-message{max-width:90%}.chat-context-options{flex-direction:column;gap:.5rem}.sidebar-header h2{font-size:1.3rem}}.context-interface{height:100%;display:flex;flex-direction:column;background:var(--bg-primary)}.context-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border-secondary);background:var(--bg-secondary)}.context-header h2{margin:0;color:var(--text-primary);font-size:1.2rem}.context-controls{display:flex;gap:.5rem}.btn-back{background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);border-radius:6px;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-back:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.context-sections{flex:1;overflow-y:auto;padding:1rem}.context-section{margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:8px}.context-section h3{margin:0 0 .75rem;color:var(--text-primary);font-size:1rem;font-weight:600}.context-description{color:var(--text-secondary);font-size:.85rem;margin-bottom:.75rem;line-height:1.4}.world-info strong{color:var(--text-primary);display:block;margin-bottom:.5rem}.element-counts-preview{display:flex;flex-wrap:wrap;gap:.5rem}.count-item{background:var(--bg-tertiary);padding:.25rem .5rem;border-radius:4px;font-size:.8rem;color:var(--text-secondary)}.selected-element-info{margin-bottom:1rem}.selected-element-info strong{color:var(--text-primary);font-size:.95rem}.element-type{color:var(--text-secondary);font-size:.85rem;margin-left:.5rem}.selected-element-options{display:flex;flex-direction:column;gap:.75rem}.element-level-options{display:flex;flex-direction:column;gap:.5rem;margin-left:1rem}.context-sections .context-option{color:var(--text-primary)}.context-option:hover{color:var(--brand-primary)}.category-controls{display:flex;gap:.5rem;margin-bottom:1rem}.btn-category-toggle{background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);padding:.5rem .75rem;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.context-widgets .btn-category-toggle{padding:.5rem 1rem;background:var(--bg-secondary);margin-right:.5rem}.btn-category-toggle:hover{background:var(--brand-primary);color:var(--text-inverse);border-color:var(--brand-primary)}.category-list{display:flex;flex-direction:column;gap:.5rem}.category-option{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:6px;cursor:pointer;transition:all .2s ease}.category-option:hover{background:var(--bg-hover);border-color:var(--border-hover)}.category-option input[type=checkbox]{margin-right:.75rem;accent-color:var(--brand-primary)}.category-name{flex:1;color:var(--text-primary);font-weight:500;font-size:.9rem}.category-count{color:var(--text-secondary);font-size:.8rem;margin:0 .75rem}.category-tokens{color:var(--text-tertiary);font-size:.8rem;font-family:var(--font-monospace)}.setting-item{display:flex;align-items:center;gap:1rem}.setting-item label{color:var(--text-primary);font-size:.9rem;white-space:nowrap}.setting-item input[type=number]{flex:1;padding:.5rem;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-input);color:var(--text-primary);font-size:.9rem;max-width:120px}.token-summary{background:var(--bg-tertiary)!important;border:2px solid var(--border-primary)!important}.token-display{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.token-count{font-family:var(--font-monospace);font-size:1.2rem;font-weight:600;color:var(--text-primary)}.token-label{color:var(--text-secondary);font-size:.85rem}.token-display.yellow .token-count{color:var(--status-warning)}.token-display.red .token-count{color:var(--status-error)}.token-warning{padding:.5rem .75rem;border-radius:6px;font-size:.85rem;line-height:1.4}.token-warning.yellow{background:#ffc1071a;color:var(--status-warning);border:1px solid rgba(255,193,7,.3)}.token-warning.red{background:#d32f2f1a;color:var(--status-error);border:1px solid rgba(211,47,47,.3)}.context-title-section{display:flex;align-items:center;gap:1rem}.header-token-display{display:flex;align-items:center;gap:.25rem;padding:.25rem .75rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:20px;font-family:var(--font-monospace)}.header-token-count{font-size:.85rem;font-weight:600;color:var(--text-primary)}.header-token-label{font-size:.75rem;color:var(--text-secondary)}.header-token-display.yellow .header-token-count{color:var(--status-warning)}.header-token-display.yellow{border-color:var(--status-warning);background:#ffc1070d}.header-token-display.red .header-token-count{color:var(--status-error)}.header-token-display.red{border-color:var(--status-error);background:#d32f2f0d}.loading-spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--border-secondary);border-radius:50%;border-top-color:var(--brand-primary);animation:spin 1s linear infinite;margin-right:.5rem}.loading-spinner-small{display:inline-block;width:10px;height:10px;border:1px solid var(--border-secondary);border-radius:50%;border-top-color:var(--brand-primary);animation:spin 1s linear infinite}.loading-text{color:var(--text-secondary);font-style:italic;font-size:.85rem}@keyframes spin{to{transform:rotate(360deg)}}.context-content{height:100%;overflow-y:auto;padding:1rem}.context-content .context-title-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-secondary)}.context-left-controls{display:flex;align-items:center}.persist-widgets-control{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.persist-widgets-control input[type=checkbox]{margin:0;cursor:pointer}.persist-widgets-control span{cursor:pointer}.context-header-controls{display:flex;align-items:center;gap:1rem}.config-help{display:flex;align-items:center;cursor:help;color:var(--text-secondary);opacity:.7;transition:opacity .2s ease}.config-help:hover{opacity:1;color:var(--text-primary)}.config-help .material-icons-outlined{font-size:16px}.model-selector-control{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.model-selector-control label{color:var(--text-secondary);font-weight:500}.model-selector-control select{padding:.25rem .5rem;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;cursor:pointer;min-width:100px}.model-selector-control select:focus{outline:none;border-color:var(--brand-primary)}.max-tokens-control{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.max-tokens-control label{color:var(--text-secondary);font-weight:500}.max-tokens-control input{width:90px;padding:.25rem .5rem;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem}.context-content h3{margin:0;color:var(--text-primary)}.context-content .context-sections{display:flex;flex-direction:column;gap:1.5rem}.context-widgets{display:flex;gap:.75rem;margin-bottom:1rem;margin-top:.5rem;overflow-x:auto;padding-bottom:.5rem}.context-widgets.world-data-row{margin-bottom:.5rem}.context-widgets.onlyworlds-knowledge-row{margin-top:0;margin-bottom:1rem}.onlyworlds-widget{background:rgba(var(--brand-primary-rgb),.02);border-color:rgba(var(--brand-primary-rgb),.15)}.onlyworlds-widget:hover:not(.clicking){border-color:var(--brand-primary);background:rgba(var(--brand-primary-rgb),.04)}.onlyworlds-widget.enabled{border-color:var(--brand-primary);background:rgba(var(--brand-primary-rgb),.06)}.onlyworlds-widget.independent{background:#78787808;border-color:#78787833}.onlyworlds-widget.independent:hover:not(.clicking){border-color:#78787866;background:#7878780d}.onlyworlds-widget.independent.enabled{background:#78787814;border-color:#78787866}.widget-required{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--brand-primary);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700}.config-refresh{cursor:pointer}.context-widget{flex:1;min-width:120px;max-width:150px;background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:8px;padding:.75rem;transition:all .3s ease;cursor:pointer;position:relative;opacity:1;min-height:100px;display:flex;flex-direction:column}.context-widget:hover:not(.clicking){border-color:var(--brand-primary)}.context-widget.clicking{transform:none;margin-top:0}.context-widget.enabled{border-color:var(--brand-primary);background:var(--brand-primary-light)}.context-widget.disabled{opacity:.5;cursor:not-allowed}.context-widget.disabled:hover{transform:none;border-color:var(--border-primary)}.widget-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.widget-toggle{display:flex;align-items:center}.widget-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.widget-toggle input[type=checkbox]:disabled{cursor:not-allowed}.widget-required{color:var(--status-success);font-weight:700;font-size:16px}.widget-icon{color:var(--text-secondary)}.widget-icon .material-icons-outlined{font-size:24px}.context-widget[data-widget-id=world-minimal] .widget-icon .material-icons-outlined{font-size:18px;padding:3px 0}.context-widget[data-widget-id=selected-minimal] .widget-icon .material-icons-outlined{font-size:16px;padding:4px 0}.widget-content{text-align:left;flex:1;display:flex;flex-direction:column;justify-content:flex-start}.widget-title{margin:0 0 .75rem;font-size:.8rem;font-weight:600;color:var(--text-primary);line-height:1.1;min-height:1.1rem;display:flex;align-items:center;justify-content:flex-start}.widget-expand{display:flex;justify-content:center;padding:0 .75rem;background:var(--bg-tertiary);border-radius:4px;cursor:pointer;transition:all .2s ease;margin-top:0;align-self:center;min-width:60px}.widget-expand:hover{background:var(--brand-primary);color:var(--text-inverse)}.widget-expand .material-icons-outlined{font-size:18px}.widget-expand.expanded{background:var(--brand-primary);color:var(--text-inverse)}.widget-status{display:flex;align-items:center}.widget-status.enabled .material-icons-outlined{color:var(--status-success)}.widget-status.disabled .material-icons-outlined{color:var(--text-muted)}.context-widget:not([data-widget-id=world-minimal]){cursor:pointer}.widget-expand{cursor:pointer}.widget-details{min-height:0;max-height:400px;overflow-y:auto;background:var(--bg-tertiary);border-radius:8px;transition:all .3s ease}.widget-details[data-expanded]{padding:1rem;margin-bottom:1rem}.widget-detail-content h4{margin:0 0 1rem;color:var(--text-primary);border-bottom:1px solid var(--border-secondary);padding-bottom:.5rem}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.detail-header h4{margin:0;border-bottom:1px solid var(--border-secondary);padding-bottom:.5rem;flex:1}.header-token-estimate{font-family:var(--font-monospace);font-size:.8rem;color:var(--text-secondary);font-weight:600;margin-left:1rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem;margin-top:1rem}.category-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-secondary);border-radius:6px;cursor:pointer;transition:background .2s ease}.category-checkbox:hover{background:var(--bg-hover)}.category-checkbox input[type=checkbox]{margin:0}.no-element{color:var(--text-muted);font-style:italic}.token-estimate{font-family:var(--font-monospace);color:var(--text-secondary);background:var(--bg-secondary);padding:.5rem;border-radius:4px;margin-top:1rem}.includes-list{display:flex;flex-direction:column;gap:.5rem}.include-item{display:flex;align-items:center;gap:.5rem;padding:.25rem 0}.include-item .material-icons-outlined{font-size:18px;color:var(--text-secondary);width:20px;flex-shrink:0}.include-item.category-item{padding-left:1rem;font-size:.9rem;color:var(--text-secondary)}.category-compact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(40px,1fr));gap:.5rem;margin-top:1rem}.category-compact-checkbox{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;background:var(--bg-secondary);border-radius:6px;cursor:pointer;transition:background .2s ease;text-align:center}.category-compact-checkbox:hover{background:var(--bg-hover)}.category-compact-checkbox input[type=checkbox]{margin:0;width:14px;height:14px}.category-compact-checkbox .material-icons-outlined{font-size:18px;color:var(--text-secondary)}.category-compact-checkbox .category-count{font-size:.7rem;color:var(--text-secondary);font-weight:600}.category-compact-checkbox .category-tokens{font-size:.6rem;color:var(--text-muted);font-family:var(--font-monospace);margin-top:.1rem}.category-icons-compact{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.category-icon-item{display:flex;flex-direction:column;align-items:center;min-width:40px}.category-icon-item .material-icons-outlined{font-size:16px;color:var(--text-secondary)}.category-icon-count{font-size:.7rem;color:var(--text-muted);font-weight:600;margin-top:.2rem}.token-indicator{font-family:var(--font-monospace);font-size:.8rem;padding:.25rem .5rem;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-primary)}.token-indicator.yellow{color:var(--status-warning);border-color:var(--status-warning);background:#ffc1071a}.token-indicator.red{color:var(--status-error);border-color:var(--status-error);background:#d32f2f1a}.preferences-feedback{position:fixed;bottom:2rem;right:2rem;background:var(--brand-primary);color:var(--text-inverse);padding:.75rem 1rem;border-radius:6px;box-shadow:var(--shadow-md);font-size:.9rem;z-index:1000;animation:slideInFade .3s ease}@keyframes slideInFade{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.context-sections,.context-section{padding:.75rem}.category-controls{flex-direction:column}.btn-category-toggle{text-align:center}.setting-item{flex-direction:column;align-items:stretch;gap:.5rem}.setting-item input[type=number]{max-width:none}.element-counts-preview{justify-content:center}}.auth-inputs{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.main-auth-group{display:flex;align-items:center;gap:8px}.mode-indicator{display:flex;align-items:center;gap:10px;margin-left:15px;padding:0}.mode-badge{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.mode-badge.online{background:var(--status-success);color:var(--text-inverse)}.mode-badge.local{background:var(--status-info);color:var(--text-inverse)}.mode-badge.none{background:var(--border-primary);color:var(--text-tertiary)}.mode-icon{font-size:14px}.mode-switch-btn{padding:4px 8px;background:transparent;color:var(--brand-primary);border:1px solid var(--brand-primary);border-radius:4px;font-size:11px;cursor:pointer;transition:all .2s ease}.mode-switch-btn:hover{background:var(--brand-primary);color:var(--text-inverse)}.welcome-options{display:flex;flex-direction:column;gap:20px;margin-top:30px;max-width:600px}.welcome-option{padding:20px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-primary)}.welcome-option h3{margin:0 0 10px;color:var(--text-primary);font-size:18px}.welcome-option p{margin:8px 0;color:var(--text-secondary)}.welcome-divider{text-align:center;color:var(--text-tertiary);font-weight:500;position:relative}.welcome-divider:before,.welcome-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border-primary)}.welcome-divider:before{left:0}.welcome-divider:after{right:0}.welcome-help{font-size:14px;font-style:italic;color:var(--text-tertiary)}.mode-switch-modal .modal-content{max-width:500px}.local-changes-info{background:var(--bg-secondary);padding:15px;border-radius:6px;margin-top:15px;border-left:4px solid var(--brand-primary)}.local-changes-info h4{margin:0 0 10px;color:var(--text-primary);font-size:14px}.local-changes-info ul{margin:0;padding-left:20px;color:var(--text-secondary);font-size:14px}@media (max-width: 768px){.auth-inputs-left,.auth-inputs-right{flex-direction:column;align-items:stretch;gap:8px}.auth-bar-content{flex-direction:column;align-items:stretch;gap:10px}.main-auth-group{width:100%;justify-content:center;flex-wrap:wrap;gap:10px}.mode-indicator{margin-left:0;margin-top:8px;justify-content:center}.welcome-options{gap:15px}.welcome-option{padding:15px}}.export-modal .modal-content{max-width:600px;width:90vw}.export-modal .modal-body{padding-bottom:0}.export-section{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border-primary)}.export-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.export-section h4{margin:0 0 10px;color:var(--text-primary);font-size:16px;display:flex;align-items:center;gap:8px}.export-section p{margin:0 0 15px;color:var(--text-secondary);font-size:14px}.export-description{margin-top:5px;margin-bottom:10px;padding:0;font-size:12px;font-style:italic;color:var(--text-tertiary);text-align:left}.export-section .btn{margin-top:10px}.export-section .btn-small{padding:8px 16px;font-size:14px;border-radius:4px}.upload-form{margin-top:15px}.upload-inputs{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}.upload-input{padding:8px 12px;font-size:14px;background:var(--bg-input);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:4px;transition:all .2s;width:120px;max-width:120px}.upload-input:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 2px var(--brand-primary-20)}.upload-input::placeholder{color:var(--text-tertiary)}.upload-input-pin{width:60px;max-width:60px;text-align:center}.upload-input:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-tertiary)}.export-status{margin-top:20px;padding:12px 16px;border-radius:6px;font-weight:500;font-size:14px}.export-status.info{background:var(--status-info-bg);color:var(--status-info);border:1px solid var(--status-info)}.export-status.success{background:var(--status-success-bg);color:var(--status-success);border:1px solid var(--status-success)}.export-status.error{background:var(--status-error-bg);color:var(--status-error);border:1px solid var(--status-error)}.export-section .btn:disabled{opacity:.6;cursor:not-allowed}.export-section .btn.loading{background:var(--brand-primary);color:var(--text-inverse);opacity:.8}.export-section .btn.btn-success{background:var(--status-success-bg);color:var(--status-success);border:1px solid var(--status-success);opacity:1;cursor:default}@media (max-width: 768px){.upload-inputs{flex-direction:column;align-items:flex-start}.upload-input{width:100%;max-width:200px}.upload-input-pin{width:80px;max-width:80px;text-align:center}.export-section{padding:15px}}.sidebar-controls{display:flex;gap:8px}.migration-modal .modal-content{max-width:700px;width:700px;height:608px;max-height:85vh;display:flex;flex-direction:column}.migration-modal-content{display:flex;flex-direction:column}.modal-header-actions{display:flex;gap:8px;align-items:center}.modal-help{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.modal-help:hover{color:var(--brand-primary)}.modal-help .material-icons-outlined{font-size:22px}.migration-tabs{display:flex;border-bottom:1px solid var(--border-secondary);background:var(--bg-secondary)}.migration-tab{flex:1;padding:12px 16px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;border-bottom:2px solid transparent}.migration-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.migration-tab.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary);background:var(--bg-primary)}.migration-tab .tab-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--bg-tertiary);font-size:12px;font-weight:600}.migration-tab.active .tab-number{background:var(--brand-primary);color:#fff}.migration-body{flex:1;overflow-y:auto;min-height:400px;max-height:498px}.migration-tab-content{padding:16px 20px 0}.migration-description{color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.label-hint{color:var(--text-tertiary);font-weight:400;font-size:12px}#migration-json-input{font-family:Courier New,monospace;font-size:13px;width:100%;min-height:300px;padding:12px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);resize:vertical}#migration-json-input:focus{outline:none;border-color:var(--brand-primary)}.migration-format-detected{display:flex;gap:10px;margin-top:8px;min-height:24px}.format-badge{display:inline-block;padding:4px 12px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:12px;font-size:12px;font-weight:500}.form-help{display:block;margin-top:6px;color:var(--text-tertiary);font-size:12px}.validation-status{margin-bottom:20px}.validation-error-header,.validation-success{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;border-radius:6px}.validation-error-header{background:#dc26261a;border:1px solid rgba(220,38,38,.3)}.validation-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3)}.validation-success-compact{padding:10px 14px}.validation-success-compact h3{margin:0 0 2px;font-size:13px;font-weight:500}.validation-success-compact p{margin:0;font-size:12px;color:var(--text-secondary)}.validation-error-header h3,.validation-success h3{margin:0;color:var(--text-primary);font-size:13px;font-weight:500}.validation-success p{margin:4px 0 0;color:var(--text-secondary)}.error-icon{color:#dc2626;font-size:20px}.success-icon{color:#22c55e;font-size:20px}.warning-icon{color:#f59e0b;font-size:20px}.validation-errors{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.validation-error-item{display:flex;gap:12px;padding:16px;background:var(--bg-secondary);border-radius:6px;border-left:3px solid #dc2626}.error-number{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#dc2626;color:#fff;border-radius:50%;font-size:14px;font-weight:600}.error-content{flex:1}.error-friendly-message{color:var(--text-primary);margin-bottom:10px;line-height:1.5;font-size:14px}.error-friendly-message strong{font-weight:600;color:var(--brand-primary)}.error-friendly-message em{font-style:italic;color:var(--text-secondary)}.error-toggle{background:none;border:none;color:var(--text-tertiary);font-size:12px;padding:4px 0;cursor:pointer;display:flex;align-items:center;gap:4px;transition:color .2s;margin-bottom:8px}.error-toggle:hover{color:var(--text-primary)}.error-toggle .material-icons-outlined{font-size:16px}.error-technical-details{margin-top:8px;padding:10px;background:var(--bg-tertiary);border-radius:4px;font-size:12px}.error-path{font-family:Courier New,monospace;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.error-issue{color:#dc2626;margin-bottom:8px;font-weight:500}.error-details{color:var(--text-secondary);font-size:13px;line-height:1.6;margin-bottom:8px}.error-fix{margin-top:8px;padding:8px 12px;background:var(--bg-tertiary);border-radius:4px;font-size:13px}.error-fix code{font-family:Courier New,monospace;color:var(--brand-primary)}.chatgpt-prompt-section{margin-top:20px;padding:16px;background:var(--bg-secondary);border-radius:6px}.chatgpt-prompt-section label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary)}.chatgpt-prompt-section textarea{width:100%;padding:12px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-secondary);font-family:Courier New,monospace;font-size:12px;resize:vertical}#copy-chatgpt-btn{margin-top:10px;display:flex;align-items:center;gap:6px}.conflicts-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}.conflicts-header h3{margin:0 0 8px;color:var(--text-primary);font-size:15px;font-weight:500}.conflicts-header p{margin:0;color:var(--text-secondary);font-size:13px}.conflicts-list{display:flex;flex-direction:column;gap:16px}.conflict-item{padding:16px;background:var(--bg-secondary);border-radius:6px;border-left:3px solid #f59e0b}.conflict-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.conflict-item .element-icon{font-size:20px;color:var(--text-secondary)}.conflict-name{font-weight:600;color:var(--text-primary);font-size:15px}.conflict-comparison{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.conflict-side label{display:block;font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;margin-bottom:6px}.conflict-preview{padding:10px;background:var(--bg-primary);border-radius:4px;font-size:13px;color:var(--text-secondary);line-height:1.5;max-height:80px;overflow:hidden}.conflict-resolution{display:flex;gap:16px;margin-bottom:8px}.conflict-resolution label{display:flex;align-items:center;gap:8px;cursor:pointer;color:var(--text-primary);font-size:14px}.conflict-resolution input[type=radio]{cursor:pointer}.conflict-warning{padding:8px 0;color:var(--text-secondary);font-size:12px}.import-summary{padding:16px;background:var(--bg-secondary);border-radius:6px}.import-summary h3{display:flex;align-items:center;gap:8px;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--border-secondary);color:var(--text-primary);font-size:15px;font-weight:500}.import-category{margin-bottom:16px}.import-category:last-child{margin-bottom:0}.import-category-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-primary)}.import-category-header .material-icons-outlined{font-size:18px;color:var(--brand-primary)}.import-category-header strong{font-size:13px;font-weight:600}.import-element-list-final{list-style:none;padding:0;margin:0}.import-element-item{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:2px;background:var(--bg-primary);border-radius:4px}.import-icon-new{font-size:18px;color:#22c55e}.import-icon-overwrite{font-size:18px;color:#f59e0b}.import-icon-skip{font-size:18px;color:#6b7280}.import-element-item .element-icon{font-size:20px;color:var(--text-secondary)}.import-element-item .element-name{font-size:13px;color:var(--text-primary);font-weight:500}.import-target{margin-bottom:20px}.import-target label{display:block;margin-bottom:12px;font-weight:600;color:var(--text-primary)}.target-options{display:flex;flex-direction:column;gap:10px}.target-options label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:10px;background:var(--bg-primary);border-radius:4px;border:1px solid var(--border-primary);transition:all .2s ease}.target-options label:hover{border-color:var(--brand-primary)}.target-options input[type=radio]{cursor:pointer}.import-warning{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:4px}.import-warning .material-icons-outlined{font-size:16px;color:#f59e0b}.import-warning p{margin:0;color:var(--text-secondary);font-size:12px}.migration-actions-bar{padding:12px 20px;border-bottom:1px solid var(--border-secondary);background:var(--bg-primary);min-height:58px;display:flex;align-items:center}.migration-actions{display:flex;justify-content:space-between;gap:12px;width:100%}.migration-actions:has(>button:only-child){justify-content:flex-end}.migration-actions-compact{margin-top:12px;padding-top:12px}.migration-actions-input{margin-top:8px;padding-top:8px;border-top:none}.migration-actions button{text-transform:lowercase}.migration-actions button .material-icons-outlined{vertical-align:middle;margin-right:4px;font-size:18px}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.rotating{animation:rotate 1s linear infinite}@media (max-width: 768px){.migration-modal .modal-content{max-width:95vw;max-height:90vh}.migration-tabs{overflow-x:auto}.migration-tab{font-size:12px;padding:10px 12px}.conflict-comparison,.summary-stats{grid-template-columns:1fr}}.import-target-section{margin:20px 0;padding:15px;background:var(--background-secondary);border-radius:8px}.import-target-section h4{margin:0 0 10px;color:var(--text-primary)}.import-target-section .target-options{display:flex;flex-direction:column;gap:10px}.import-target-section .target-options label{display:flex;flex-direction:column;padding:10px;border:2px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s}.import-target-section .target-options label:hover{border-color:var(--primary-color);background:var(--background-hover)}.import-target-section .target-options input[type=radio]:checked+strong,.import-target-section .target-options label:has(input[type=radio]:checked){border-color:var(--primary-color);background:var(--background-hover)}.import-target-section .target-hint{font-size:.9em;color:var(--text-secondary);margin-top:4px}
