*{margin:0;padding:0;box-sizing:border-box;font-family:system-ui,sans-serif;touch-action:manipulation}body{height:100vh;overflow:hidden;background:#f2f2f7}.app{height:100vh;display:flex;flex-direction:column}.pages{flex:1;position:relative}.page{position:absolute;left:0;top:0;width:100%;height:100%;padding:12px;overflow-y:auto;background:#f2f2f7;display:none}#page-chat-detail{display:none;flex-direction:column;padding:0}.header{display:flex;justify-content:space-between;align-items:center;padding:12px 0;margin-bottom:8px}.header-title{font-size:22px;font-weight:700}.btn{padding:8px 14px;border:none;border-radius:8px;background:#007aff;color:white;cursor:pointer}.btn-green{background:#34c759}.btn-red{background:#ff3b30}.btn-back{background:transparent;color:#007aff;border:none;font-size:20px;cursor:pointer}.btn-close{background:transparent;border:none;font-size:24px;cursor:pointer;color:#ff3b30;line-height:1;padding:0;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%}.btn-close:hover{color:#c00;background:#ffe5e5;transform:scale(1.05)}.search-box{margin-bottom:12px;padding:8px;background:#fff;border-radius:8px;display:flex;align-items:center;gap:8px}.search-box input{flex:1;border:none;padding:8px;font-size:16px;outline:none;background:transparent}.item{background:white;border-radius:12px;padding:14px;margin:8px 0;display:flex;align-items:center;gap:10px;box-shadow:0 1px 2px #00000008;position:relative;cursor:pointer}.item-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:#f2f2f7;overflow:hidden;flex-shrink:0}.item-icon img{width:100%;height:100%;object-fit:cover}.item-body{flex:1;min-width:0}.item-title{font-size:17px;font-weight:600;margin-bottom:2px}.item-desc{font-size:13px;color:#8e8e93;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-actions{position:absolute;right:14px;top:50%;transform:translateY(-50%);z-index:10}.menu-btn{width:32px;height:32px;border-radius:50%;background:#f2f2f7;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.menu-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:white;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,0.15);min-width:140px;z-index:20;display:none}.menu-dropdown a{display:block;padding:10px 16px;color:#333;text-decoration:none;font-size:14px;cursor:pointer}.menu-dropdown a:hover{background:#f2f2f7}.nav{height:60px;background:white;border-top:1px solid #d1d1d6;display:flex}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#8e8e93;cursor:pointer}.nav-item.active{color:#007aff}.nav-icon{font-size:22px;margin-bottom:2px}.nav-text{font-size:12px}.chat-header{padding:12px;background:white;border-bottom:1px solid #d1d1d6;display:flex;align-items:center;gap:10px}.chat-back{padding:6px 10px;background:#f2f2f7;border:none;border-radius:6px;cursor:pointer}.chat-avatar{width:36px;height:36px;border-radius:50%;background:#f2f2f7;display:flex;align-items:center;justify-content:center;font-size:18px;overflow:hidden}.chat-avatar img{width:100%;height:100%;object-fit:cover}.chat-title{font-size:17px;font-weight:600}.chat-messages{flex:1;padding:12px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.msg{position:relative;max-width:75%;display:flex;flex-direction:column;margin-bottom:4px}.msg.user{align-self:flex-end}.msg.ai{align-self:flex-start}.msg .bubble{display:inline-block;padding:10px 12px;border-radius:16px;word-wrap:break-word;position:relative}.msg.user .bubble{background:#007aff;color:white}.msg.ai .bubble{background:white;color:#000000}.msg-info-bar{margin-top:6px;font-size:10px;color:#8e8e93;display:flex;align-items:center;gap:4px}.msg-info-menu-btn{background:none;border:none;font-size:12px;cursor:pointer;color:#8e8e93;margin-left:4px}.msg-menu-dropdown{position:fixed;background:white;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,0.15);z-index:1000;min-width:160px}.msg-menu-dropdown a{display:block;padding:10px 16px;color:#333;text-decoration:none;font-size:14px;cursor:pointer}.msg-menu-dropdown a:hover{background:#f2f2f7}.input-area{padding:8px 12px;background:white;border-top:1px solid #d1d1d6;display:flex;align-items:center;gap:8px;position:relative}.global-menu-btn{background:none;border:none;font-size:24px;cursor:pointer;padding:8px;border-radius:12px;color:#007aff}.input-bar{flex:1;display:flex;gap:8px;align-items:flex-end}.input-bar textarea{flex:1;padding:10px 14px;border:1px solid #d1d1d6;border-radius:20px;resize:none;font-family:system-ui,sans-serif;font-size:16px;line-height:1.4;max-height:200px;overflow-y:hidden;min-height:40px}.input-bar button{padding:0 16px;background:#007aff;color:white;border:none;border-radius:20px;cursor:pointer;height:40px;align-self:flex-end}.global-menu{position:absolute;bottom:100%;left:0;margin-bottom:0;background:white;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,0.15);z-index:999;display:none;width:200px}.global-menu a{display:block;padding:12px 16px;color:#333;text-decoration:none;font-size:14px;cursor:pointer}.global-menu a:hover{background:#f2f2f7}.setting-group{display:flex;flex-direction:column;gap:10px;margin-top:10px}.setting-item{background:white;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;cursor:pointer}.setting-icon{width:40px;height:40px;border-radius:50%;background:#f2f2f7;display:grid;place-items:center;font-size:18px}.setting-body{flex:1}.setting-title{font-size:17px;font-weight:600}.setting-sub{font-size:13px;color:#8e8e93;margin-top:2px}.form{background:white;border-radius:12px;padding:16px;margin:12px 0;display:none}.form-item{margin-bottom:16px}.form-item label{display:block;margin-bottom:8px;font-size:15px;color:#333}.form-item input,.form-item textarea,.form-item select{width:100%;padding:12px;border:1px solid #e5e5e5;border-radius:12px;background:#f8f9fa;font-size:16px}.form-item textarea{resize:vertical;height:100px}.modal{position:fixed;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,0.5);display:none;place-items:center;z-index:999}.modal-box{background:white;border-radius:16px;width:95vw;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;padding:20px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-title{font-size:20px;font-weight:700}.modal-body{flex:1;overflow-y:auto}.modal-footer{margin-top:16px;display:flex;justify-content:flex-end;gap:12px}.modal-footer button{padding:8px 16px;border-radius:8px}.switch{position:relative;display:inline-block;width:48px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#ccc;border-radius:24px;transition:0.2s}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:white;border-radius:50%;transition:0.2s}input:checked+.slider{background:#007aff}input:checked+.slider:before{transform:translateX(24px)}.preset-top-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 0}.preset-top-bar h1{font-size:22px;font-weight:700}.preset-btn-group{display:flex;gap:12px}.preset-item-row{background:white;border:1px solid #e5e5e5;border-radius:8px;padding:8px;margin-bottom:4px;display:flex;align-items:center;gap:12px;width:100%}.preset-drag{color:#c7c7cc;font-size:20px;cursor:grab;min-width:24px;text-align:center}.preset-item-name{flex:1;font-size:16px;word-break:break-word;min-width:0}.preset-item-edit{color:#007aff;font-size:20px;cursor:pointer;min-width:24px;text-align:center}.preset-item-delete{color:#ff3b30;font-size:20px;cursor:pointer;min-width:24px;text-align:center}.preset-empty{text-align:center;padding:40px 20px;color:#8e8e93}#preset-items-container{max-height:calc(95vh - 180px);overflow-y:auto;padding-right:4px;width:100%}.import-upload-area{margin:16px 0;padding:24px;border:2px dashed #ccc;border-radius:12px;text-align:center;display:none}.upload-icon{font-size:48px;color:#007aff;margin-bottom:12px}.upload-title{font-size:24px;font-weight:600;margin-bottom:8px}.upload-desc{font-size:16px;color:#666;margin-bottom:20px}.upload-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.upload-btn{padding:14px;border:none;border-radius:12px;font-size:18px;font-weight:500;color:white;cursor:pointer}.upload-btn.file{background:#007aff}.upload-btn.album{background:#34c759}.upload-format{font-size:14px;color:#999}.single-preview{display:none;margin-top:20px}.function-tip{background:#fff9cc;color:#b88200;padding:8px 16px;border-radius:20px;font-size:14px;margin:12px 0;display:inline-block}.avatar-container{text-align:center;margin:16px 0}.avatar{width:180px;height:180px;border-radius:16px;object-fit:cover;border:2px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,0.1)}.card{background:white;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 1px 2px #00000008}.card-worldbook{background:#f8f0fc;border:1px solid #e9d5ff}.card-script{background:#eff6ff;border:1px solid #bfdbfe}.card-title{font-size:16px;font-weight:600;margin-bottom:8px;color:#333}.card-subtitle{font-size:14px;color:#8e8e93;margin-bottom:8px}.card-action{font-size:14px;color:#007aff;cursor:pointer}.preview-footer{display:flex;gap:12px;margin-top:20px}.btn-save{flex:2;padding:14px;background:#007aff;border:none;border-radius:12px;color:white;font-size:18px;font-weight:500;cursor:pointer}.btn-clear{flex:1;padding:14px;background:#e9ecef;border:none;border-radius:12px;color:#495057;font-size:18px;font-weight:500;cursor:pointer}.batch-item{padding:12px;border-radius:12px;margin-bottom:8px;display:flex;align-items:center;gap:10px}.batch-item.success{background:#e8f5e9;border:1px solid #c8e6c9}.batch-item.error{background:#ffebee;border:1px solid #ffcdd2}.batch-dot{width:10px;height:10px;border-radius:50%}.batch-dot.success{background:#4caf50}.batch-dot.error{background:#f44336}.batch-info{flex:1}.batch-name{font-size:16px;font-weight:500;margin-bottom:4px}.batch-error{font-size:14px;color:#d32f2f}.batch-tags{display:flex;gap:6px;margin-top:4px}.batch-tag{padding:2px 6px;border-radius:4px;font-size:12px}.tag-world{background:#f3e5f5;color:#9c27b0}.tag-script{background:#e3f2fd;color:#1976d2}.batch-check{color:#4caf50;font-size:20px}.batch-close{color:#f44330;font-size:20px;cursor:pointer}.modal-buttons{display:flex;gap:12px;margin-top:20px}.modal-buttons .btn{flex:1;padding:12px;border-radius:12px;font-size:16px}.empty-state{text-align:center;padding:40px 12px;color:#8e8e93}.empty-icon{font-size:48px;margin-bottom:12px}.empty-text{font-size:17px;margin-bottom:16px}.expandable-content{margin-top:12px;padding:12px;background:#fff;border-radius:8px;border:1px solid #e5e5e5;max-height:300px;overflow-y:auto}.entry-item{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #f0f0f0}.entry-item:last-child{border-bottom:none}.entry-title{font-weight:600;color:#7e22ce;margin-bottom:4px}.entry-keywords{font-size:13px;color:#666;margin-bottom:4px}.entry-content{font-size:13px;color:#333;line-height:1.4}.rule-item{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #e0e7ff}.rule-item:last-child{border-bottom:none}.rule-name{font-weight:600;color:#1d4ed8;margin-bottom:4px}.rule-pattern{font-size:12px;color:#666;font-family:monospace;margin-bottom:4px}.rule-replace{font-size:12px;color:#333;font-family:monospace}.item-right{display:flex;flex-direction:column;align-items:flex-end;margin-left:auto;font-size:12px;color:#8e8e93}.item-time{margin-bottom:4px}.item-info{display:flex;align-items:center;gap:6px}.item-menu-btn{background:none;border:none;font-size:16px;cursor:pointer;color:#8e8e93;padding:0 4px}.chat-menu-dropdown{position:absolute;right:0;top:100%;background:white;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,0.15);display:none;z-index:20;min-width:100px}.chat-menu-dropdown a{display:block;padding:8px 16px;color:#333;text-decoration:none;font-size:14px;cursor:pointer}.chat-menu-dropdown a:hover{background:#f2f2f7}.inline-edit-area{display:flex;flex-direction:column;gap:8px;width:100%}.inline-edit-textarea{width:100%;padding:8px;border-radius:12px;border:1px solid #ccc;font-size:14px;font-family:inherit;resize:vertical;background:#fff}.inline-edit-buttons{display:flex;gap:8px;justify-content:flex-end}.inline-edit-buttons button{padding:4px 12px;border-radius:16px;border:none;cursor:pointer;font-size:14px}.inline-edit-save{background:#34c759;color:white}.inline-edit-cancel{background:#e5e5ea;color:#333}.import-settings-panel{margin-top:20px;padding-top:16px;border-top:1px solid #e5e5e5;text-align:left}.import-settings-title{font-size:16px;font-weight:600;margin-bottom:12px;color:#333}.import-setting-row{margin-bottom:12px}.import-setting-label{font-size:14px;font-weight:500;display:block;margin-bottom:6px}.import-setting-select{width:100%;padding:10px;border:1px solid #ccc;border-radius:8px;background:#fff;font-size:14px}.import-setting-checkbox{display:flex;align-items:center;gap:8px}.import-setting-checkbox input{width:18px;height:18px}.import-setting-desc{font-size:12px;color:#8e8e93;margin-top:4px}.editable-list-panel{width:90%;max-width:600px;background:#fff;border-radius:16px;padding:20px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.panel-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.collection-name{font-size:24px;font-weight:600;color:#000;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.panel-actions{display:flex;gap:8px;flex-wrap:nowrap;align-items:center}.panel-tip{display:flex;align-items:center;gap:6px;color:#666;font-size:14px}.tip-icon{font-size:18px}.editable-list{display:flex;flex-direction:column;gap:12px;max-height:50vh;overflow-y:auto}.list-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #e5e5e5;border-radius:8px;background:#f9f9f9}.drag-handle{font-size:20px;color:#ccc;cursor:grab}.item-name{flex:1;font-size:16px;color:#000;word-break:break-word}.toggle-small{position:relative;width:48px;height:24px;flex-shrink:0}.toggle-small input{opacity:0;width:0;height:0}.toggle-slider-small{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;border-radius:24px;transition:0.4s}.toggle-slider-small:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:white;border-radius:50%;transition:0.4s}input:checked+.toggle-slider-small{background-color:#007aff}input:checked+.toggle-slider-small:before{transform:translateX(24px)}.item-edit-btn,.item-delete-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#666;padding:4px}.item-edit-btn:hover{color:#007aff}.item-delete-btn:hover{color:#ff3b30}.checkbox-group,.radio-group{display:flex;gap:16px;margin-top:8px}.checkbox-item,.radio-item{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-item input,.radio-item input{width:18px;height:18px;margin:0;cursor:pointer}.checkbox-item span,.radio-item span{font-size:16px;color:#333}.form-input{width:100%;padding:10px 12px;border:1px solid #e5e5e5;border-radius:8px;font-size:16px;background:#fff;box-sizing:border-box}.form-input:focus{outline:none;border-color:#007aff}.form-tip{margin-top:6px;font-size:12px;color:#8e8e93}.btn-cancel{background:#f2f2f7;color:#333}.btn-cancel:hover{background:#e5e5ea}.btn-lock{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 8px;margin-left:8px}.btn-lock:hover{opacity:0.7}.drag-handle{cursor:default}.list-item[draggable="true"] .drag-handle{cursor:grab}.preset-item-row[draggable="true"] .preset-drag{cursor:grab}.list-item.dragging,.preset-item-row.dragging{opacity:0.5}.panel-actions .btn-lock{margin-left:auto}.list-item,.preset-item-row{padding:8px 12px !important;margin:0 !important;min-height:40px !important;box-sizing:border-box !important;border-bottom:1px solid #eee}.drop-placeholder{background:transparent !important;margin:3px 0 !important;padding:0 !important;border:none !important;box-sizing:border-box !important;transition:all 0.2s ease !important}.sortable-ghost{opacity:0 !important;background:transparent !important}.sortable-chosen{cursor:grabbing}.sortable-drag{opacity:0.5 !important;cursor:grabbing}.sortable-fallback{cursor:grabbing}.msg-delete-checkbox{margin-right:8px;width:20px;height:20px;cursor:pointer;flex-shrink:0}.msg{display:flex;align-items:flex-start}.msg.user .msg-delete-checkbox{order:-1}.msg.ai .msg-delete-checkbox{order:1}.edit-bubble{padding:0;background:transparent}.edit-textarea{width:100%;border:none;outline:none;resize:none;font-family:inherit;font-size:inherit;line-height:inherit;background:transparent;color:inherit;overflow-y:auto;box-sizing:border-box}.edit-textarea:focus{outline:none}