:root{--c-primary: #6366F1;--c-primary-hover: #4F46E5;--c-primary-soft: #EEF2FF;--c-primary-glow: rgba(99, 102, 241, .15);--c-bg: #F7F6F3;--c-surface: #FFFFFF;--c-text: #1C1917;--c-text-2: #57534E;--c-text-3: #78716C;--c-border: rgba(0, 0, 0, .07);--c-border-hover: rgba(0, 0, 0, .14);--c-success: #059669;--c-success-soft: #ECFDF5;--c-error: #DC2626;--c-error-soft: #FEF2F2;--font: -apple-system, "SF Pro Text", "PingFang SC", "Noto Sans SC", "Microsoft YaHei", system-ui, sans-serif;--font-display: -apple-system, "SF Pro Display", "PingFang SC", "Noto Sans SC", "Microsoft YaHei", sans-serif;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 20px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-card: 0 1px 3px rgba(0,0,0,.04), 0 4px 14px rgba(0,0,0,.05);--ease: cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font);color:var(--c-text);background:var(--c-bg);line-height:1.6;min-height:100vh}.app{max-width:800px;margin:0 auto;padding:0 24px 80px}.app--wide{max-width:1100px}.main-content{margin-top:8px}.step-indicator{display:flex;align-items:center;justify-content:center;padding:28px 0 8px;gap:0}.step-item{display:flex;align-items:center;gap:10px;position:relative}.step-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;font-family:var(--font-display);color:var(--c-text-3);background:var(--c-surface);border:2px solid var(--c-border);transition:all .3s var(--ease);position:relative;z-index:1}.step-active .step-circle{background:var(--c-primary);color:#fff;border-color:var(--c-primary);box-shadow:0 0 0 4px var(--c-primary-glow)}.step-done .step-circle{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.step-label{font-size:13px;color:var(--c-text-3);font-weight:500;letter-spacing:-.2px;transition:color .3s var(--ease)}.step-active .step-label{color:var(--c-text);font-weight:600}.step-done .step-label{color:var(--c-text-2)}.step-line{width:48px;height:2px;background:var(--c-border);margin:0 14px;border-radius:1px;transition:background .3s var(--ease)}.step-done .step-line{background:var(--c-primary)}.step-clickable{cursor:pointer}.step-done:hover .step-circle{box-shadow:0 0 0 4px var(--c-primary-glow)}.step-enter{animation:slideUp .35s var(--ease) both}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.upload-page{display:flex;flex-direction:column;align-items:center;padding-top:80px;gap:36px;min-height:70vh}.upload-hero{text-align:center}.upload-title{font-family:var(--font-display);font-size:32px;font-weight:700;letter-spacing:-1px;color:var(--c-text);margin-bottom:10px;line-height:1.2}.upload-subtitle{font-size:16px;color:var(--c-text-2);font-weight:400;line-height:1.6;max-width:400px;margin:0 auto}.drop-zone{width:100%;max-width:460px;padding:56px 32px;background:var(--c-surface);border:2px dashed var(--c-border);border-radius:var(--r-xl);cursor:pointer;text-align:center;transition:all .25s var(--ease);box-shadow:var(--shadow-sm)}.drop-zone:hover{border-color:var(--c-primary);background:var(--c-primary-soft);box-shadow:var(--shadow-card);transform:translateY(-2px)}.drop-zone--active{border-color:var(--c-primary);background:var(--c-primary-soft);box-shadow:0 0 0 4px var(--c-primary-glow),var(--shadow-card)}.drop-zone--loading{pointer-events:none;opacity:.6}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:16px}.dz-icon{color:var(--c-text-3);transition:color .25s var(--ease)}.drop-zone:hover .dz-icon{color:var(--c-primary)}.dz-text{font-size:15px;font-weight:600;color:var(--c-text);letter-spacing:-.2px}.dz-hint{font-size:13px;color:var(--c-text-3)}.loading-spinner{width:28px;height:28px;border:2.5px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;animation:spin .7s linear infinite}.upload-error{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--c-error-soft);border:1px solid #FECACA;border-radius:var(--r-md);font-size:14px;color:#991b1b;max-width:460px;width:100%}.upload-footnote{font-size:12px;color:var(--c-text-3);text-align:center;max-width:460px;width:100%}.config-layout{display:flex;gap:24px;align-items:flex-start}.config-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:16px}.config-sidebar{width:280px;flex-shrink:0;position:sticky;top:20px}.config-form{background:var(--c-surface);border-radius:var(--r-lg);padding:24px;display:flex;flex-direction:column;gap:24px;box-shadow:0 1px 4px #0000000d,0 4px 14px #0000000a}.form-field{display:flex;flex-direction:column;gap:8px}.form-label{font-size:13px;font-weight:600;color:var(--c-text-2);letter-spacing:-.1px}.form-label--step{font-size:16px;font-weight:700;color:var(--c-primary);font-family:var(--font-display);letter-spacing:-.3px}.form-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.form-input{width:200px;padding:8px 12px;border:1.5px solid var(--c-border);border-radius:var(--r-md);font-size:14px;font-family:var(--font);color:var(--c-text);outline:none;background:#fafaf8;transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s}.form-input:focus{border-color:var(--c-primary);background:var(--c-surface);box-shadow:0 0 0 3px var(--c-primary-glow)}.form-input::placeholder{color:var(--c-text-3)}.form-input--empty{border-color:#f87171}.form-input--empty:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}.form-required{color:#ef4444;margin-left:2px;font-weight:400}.form-hint{font-size:12px;color:var(--c-text-3)}.form-hint--warn{color:#ef4444}.form-hint--error{color:#ef4444;font-weight:500}.form-hint--ok{color:var(--c-success);font-weight:500}.form-input--ok{border-color:var(--c-success)}.form-input--error{border-color:#ef4444}.form-input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}.wechat-field{position:relative}.wechat-confirm{display:flex;align-items:center;gap:10px;background:var(--c-primary-soft);border-radius:var(--r-md);padding:6px 12px;font-size:13px;color:var(--c-text);animation:fadeIn .2s var(--ease) both;flex-shrink:0}.wechat-confirm-id{font-weight:700;color:var(--c-primary);font-family:var(--font-display)}.wechat-confirm-actions{display:flex;align-items:center;gap:8px}.wechat-confirm-actions .btn{padding:4px 12px;font-size:12px}.dc{border-radius:var(--r-lg);border:1px solid var(--c-border);background:var(--c-surface);overflow:hidden;box-shadow:var(--shadow-sm)}.dc-top{display:flex;align-items:center;gap:14px;padding:16px 20px}.dc-icon{flex-shrink:0}.dc-info{flex:1;min-width:0}.dc-name{display:block;font-size:14px;font-weight:600;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dc-meta{display:block;font-size:12px;color:var(--c-text-3);margin-top:2px}.dc-detail{border-top:1px solid var(--c-border);animation:fadeIn .2s var(--ease) both}.dc-table-wrap{overflow-x:auto;max-height:200px;overflow-y:auto}.dc-table{width:100%;border-collapse:collapse;font-size:12px;white-space:nowrap}.dc-table th{padding:8px 14px;background:#fafaf8;font-weight:600;color:var(--c-text-2);text-align:left;border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:1}.dc-table td{padding:8px 14px;border-bottom:1px solid rgba(0,0,0,.03);color:var(--c-text)}.dc-table tr:hover td{background:#fafaf8}.dc-bottom{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#fafaf8;border-top:1px solid var(--c-border)}.dc-bottom-text{font-size:12px;color:var(--c-text-3)}.dc-mapping{padding:14px 20px;background:#fafaf8;display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--c-border)}.dc-map-row{display:flex;align-items:center;gap:12px}.dc-map-label{font-size:13px;font-weight:600;color:var(--c-text-2);min-width:100px}.dc-map-select{flex:1;padding:6px 10px;border:1.5px solid var(--c-border);border-radius:var(--r-sm);font-size:13px;font-family:var(--font);color:var(--c-text);outline:none;transition:border-color .15s}.dc-map-select:focus{border-color:var(--c-primary)}.scripts-list{display:flex;flex-direction:column;gap:12px}.sc{display:flex;flex-direction:column;background:var(--c-surface);border-radius:var(--r-lg);padding:16px 18px;box-shadow:0 1px 4px #0000000f,0 4px 12px #0000000a;transition:box-shadow .2s var(--ease),opacity .2s}.sc:hover{box-shadow:0 2px 6px #00000012,0 8px 20px #0000000f}.sc--drag{opacity:.35}.sc--over{box-shadow:0 0 0 2px var(--c-primary),0 4px 12px #6366f126}.sc-top{display:flex;align-items:center;gap:8px;margin-bottom:12px}.sc-grip{color:var(--c-text-3);cursor:grab;padding:2px;display:flex;align-items:center;opacity:.3;transition:opacity .15s}.sc-grip:hover{opacity:.6}.sc-grip:active{cursor:grabbing;opacity:1}.sc-label{font-size:15px;font-weight:700;color:var(--c-text);flex:1;letter-spacing:-.3px;font-family:var(--font-display)}.sc-type-tabs{display:flex;background:#0000000a;border-radius:6px;padding:2px;gap:2px}.sc-tab{padding:3px 10px;border:none;border-radius:4px;font-size:11px;font-weight:500;font-family:var(--font);color:var(--c-text-3);background:transparent;cursor:pointer;transition:all .15s var(--ease);white-space:nowrap}.sc-tab:hover{color:var(--c-text-2)}.sc-tab--on{background:var(--c-surface);color:var(--c-text);font-weight:600;box-shadow:0 1px 2px #00000014}.sc-del{width:24px;height:24px;border:none;border-radius:var(--r-sm);background:transparent;cursor:pointer;color:var(--c-text-3);display:flex;align-items:center;justify-content:center;transition:all .15s var(--ease);flex-shrink:0;opacity:0}.sc:hover .sc-del{opacity:1}.sc-del:hover{color:var(--c-error)}.sc-body{display:flex;flex-direction:column;gap:10px}.sc-editor{position:relative;border:1.5px solid var(--c-border);border-radius:var(--r-md);background:#fafaf8;min-height:80px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s}.sc-editor:focus-within{border-color:var(--c-primary);background:var(--c-surface);box-shadow:0 0 0 3px var(--c-primary-glow)}.sc-editor--empty{border-color:#f87171}.sc-editor--empty:focus-within{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}.sc-editor-render{padding:10px 12px;font-size:14px;font-family:var(--font);color:var(--c-text);line-height:1.6;white-space:pre-wrap;word-break:break-word;pointer-events:none}.sc-editor-render .wx-emoji{vertical-align:text-bottom}.sc-editor-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;padding:10px 12px;border:none;outline:none;font-size:14px;font-family:var(--font);line-height:1.6;white-space:pre-wrap;word-break:break-word;color:transparent;caret-color:var(--c-text);background:transparent;resize:none}.sc-editor-input::placeholder{color:var(--c-text-3)}.sc-editor-input:not(:placeholder-shown){color:transparent}.sc-editor-hint{position:absolute;bottom:-18px;left:0;font-size:11px;color:#ef4444}.sc-check{display:flex;align-items:center;gap:5px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px;color:var(--c-text-2)}.sc-check input{width:14px;height:14px;margin:0;accent-color:var(--c-primary)}.sc-article-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sc-article-label{font-size:13px;color:var(--c-text-2)}.sc-slots{display:flex;gap:4px}.sc-slot{width:32px;height:32px;border:1.5px solid var(--c-border);border-radius:var(--r-sm);background:#fafaf8;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-display);color:var(--c-text-2);display:flex;align-items:center;justify-content:center;transition:all .15s var(--ease)}.sc-slot:hover{border-color:var(--c-border-hover);background:var(--c-surface)}.sc-slot--on{border-color:var(--c-primary);background:var(--c-primary-soft);color:var(--c-primary)}.sc-note{font-size:11px;color:var(--c-text-3)}.config-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:4px}.chat-preview{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--c-border);background:#ededed;box-shadow:var(--shadow-card)}.cp-bar{padding:10px 16px;background:#f5f5f5;border-bottom:1px solid rgba(0,0,0,.06);text-align:center}.cp-bar-title{font-size:14px;font-weight:600;color:var(--c-text)}.cp-body{padding:16px 14px;min-height:260px;display:flex;flex-direction:column}.cp-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.cp-empty-main{font-size:13px;color:#999}.cp-empty-sub{font-size:11px;color:#c4c4c4}.cp-msgs{display:flex;flex-direction:column;gap:12px;flex:1}.cp-row{display:flex;align-items:flex-start;gap:8px;justify-content:flex-end}.cp-num{width:20px;height:20px;border-radius:50%;background:#0000000f;color:#00000059;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:4px}.cp-bubble{max-width:180px;padding:9px 12px;background:#95ec69;border-radius:8px;font-size:12px;color:#000;line-height:1.5;word-break:break-all;position:relative}.cp-bubble:after{content:"";position:absolute;top:10px;right:-5px;border:5px solid transparent;border-left-color:#95ec69}.cp-bubble strong{font-weight:600}.cp-article{background:#fff;padding:0;border-radius:6px;border:1px solid #E0E0E0;display:flex;align-items:stretch;overflow:hidden;max-width:200px}.cp-article:after{display:none}.cp-article-text{flex:1;padding:8px 10px;display:flex;flex-direction:column;gap:4px;min-width:0}.cp-article-title{font-size:13px;font-weight:600;color:#333;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cp-article-desc{font-size:10px;color:#999;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cp-article-thumb{width:48px;flex-shrink:0;background:#f0f0f0;display:flex;align-items:center;justify-content:center;border-left:1px solid #EEE}.cp-avatar{width:32px;height:32px;background:var(--c-primary);border-radius:6px;color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn{padding:9px 20px;border:none;border-radius:var(--r-md);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .2s var(--ease);letter-spacing:-.2px}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--c-primary-hover)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-lg{padding:12px 28px;font-size:15px}.btn-downloaded{background:var(--c-success)}.btn-downloaded:hover{background:#047857}.link-btn{background:none;border:none;padding:4px 0;font-size:13px;font-weight:500;font-family:var(--font);color:var(--c-text-3);cursor:pointer;transition:color .15s var(--ease)}.link-btn:hover{color:var(--c-text)}.link-btn--sm{font-size:12px}.preview-page{display:flex;flex-direction:column;gap:16px}.preview-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.preview-header-info{display:flex;flex-direction:column;gap:2px}.preview-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-text);letter-spacing:-.3px}.preview-meta{font-size:13px;color:var(--c-text-3)}.preview-download{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.preview-save-hint{font-size:12px;color:var(--c-text-2);line-height:1.6;text-align:right}.preview-save-path{background:#0000000d;padding:2px 6px;border-radius:4px;font-family:Consolas,Courier New,monospace;font-size:11px;color:var(--c-text);word-break:break-all}.preview-save-link{margin-left:6px;color:var(--c-primary);text-decoration:none;font-weight:500}.preview-save-link:hover{text-decoration:underline}.preview-table-section{background:var(--c-surface);border-radius:var(--r-lg);padding:20px;border:1px solid var(--c-border);box-shadow:var(--shadow-sm)}.preview-count{font-size:12px;font-weight:400;color:var(--c-text-3)}.table-scroll{overflow-x:auto;border-radius:var(--r-sm);border:1px solid var(--c-border)}.preview-table{width:100%;border-collapse:collapse;font-size:12px;white-space:nowrap}.preview-table th{padding:10px 14px;background:#fafaf8;font-weight:600;color:var(--c-text-2);text-align:left;border-bottom:1px solid var(--c-border)}.preview-table td{padding:9px 14px;border-bottom:1px solid rgba(0,0,0,.03);color:var(--c-text);max-width:280px;white-space:pre-wrap;word-break:break-all}.preview-table tr:last-child td{border-bottom:none}.preview-table tr:hover td{background:#fafaf8}.cell-script{color:var(--c-primary);font-weight:500}.cell-empty{color:var(--c-text-3)}.preview-empty{text-align:center;padding:32px 16px;color:var(--c-text-3)}.preview-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:8px}.dl-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.dl-dialog{background:var(--c-surface);border-radius:var(--r-lg);padding:28px 32px;max-width:440px;width:90%;box-shadow:0 20px 60px #0003}.dl-dialog-title{font-size:18px;font-weight:700;color:var(--c-text);font-family:var(--font-display);margin-bottom:12px}.dl-dialog-text{font-size:14px;color:var(--c-text-2);margin-bottom:8px}.dl-dialog-path{display:block;background:#0000000a;padding:10px 14px;border-radius:var(--r-md);font-family:Consolas,Courier New,monospace;font-size:13px;color:var(--c-text);word-break:break-all;margin-bottom:12px}.dl-dialog-actions{display:flex;align-items:center;justify-content:space-between;margin-top:20px}.dl-dialog-btns{display:flex;gap:8px}@media(max-width:840px){.config-layout{flex-direction:column}.config-sidebar{width:100%;position:static}}@media(max-width:640px){.app,.app--wide{padding:0 14px 48px}.upload-page{padding-top:52px;gap:28px}.upload-title{font-size:26px}.step-label{display:none}.step-line{width:28px;margin:0 8px}.drop-zone{padding:44px 20px}.config-form{padding:16px}.form-input{width:100%}.config-actions{flex-direction:column}.preview-header{flex-direction:column;align-items:stretch}.preview-header .btn{width:100%;justify-content:center}}
