:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:#183246}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,#f5fbff,#eef5fb)}.app-shell{min-height:100vh}.global-header{position:fixed;top:0;left:0;right:0;height:64px;z-index:10010;background:#fffffff5;border-bottom:1px solid #dce9f5;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.global-header-inner{height:100%;width:calc(100% - 60px);margin:0 30px;display:flex;align-items:center;justify-content:space-between}.global-brand{font-size:20px;font-weight:800;color:#1d4662}.global-brand-btn{border:0;background:transparent;padding:0;cursor:pointer}.global-actions{display:flex;align-items:center;gap:10px;height:100%}.user-menu-wrap{position:relative;display:flex;align-items:center}.global-header .primary.small{width:auto;margin-top:0;padding:8px 12px;font-size:13px;display:inline-flex;align-items:center;justify-content:center;line-height:1.2}.user-menu-popup{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;padding:8px;border-radius:12px;border:1px solid #dce9f5;background:#fff;box-shadow:0 12px 24px #123d5e29}.user-menu-name{padding:8px 10px;font-size:13px;font-weight:700;color:#35586f}.header-points-badge{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:10px;background:#fff7dc;border:1px solid #f6d878}.points-icon{display:block;flex-shrink:0}.points-number{font-weight:900;font-size:13px;color:#7a5a00}.user-name-inline{font-weight:800}.user-menu-item{width:100%;border:none;background:#f7fbff;color:#244c66;border-radius:10px;padding:10px 12px;text-align:left;font-weight:700;cursor:pointer}.user-menu-item.danger{color:#b8322d;background:#fff4f3}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#1224346b;z-index:10020;display:flex;align-items:center;justify-content:center;padding:16px}.modal-card{width:min(520px,100%);background:#fff;border-radius:14px;border:1px solid #dce9f5;padding:14px;box-shadow:0 12px 24px #123d5e33;max-height:calc(100vh - 32px);overflow-y:auto;overscroll-behavior:contain}.auth-modal-card{width:min(460px,100%)}.auth-modal-card .modal-title-row,.auth-modal-card .modal-item,.auth-modal-card .modal-actions,.auth-modal-card .hint{text-align:left}.auth-modal-card .modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.auth-modal-card .modal-actions button{width:100%}.modal-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.modal-title-row h3{margin:0;font-size:18px}.modal-item{border:1px solid #e4eef7;border-radius:10px;background:#fafdff;padding:10px}.api-base-input{width:100%;margin-top:8px;border-radius:10px;border:1px solid #dce9f5;padding:8px 10px;background:#fff;font-size:13px}.cache-size{margin-top:4px;font-size:16px;font-weight:700;color:#244c66}.modal-actions{display:flex;gap:10px;margin-top:12px}.env-list{margin-top:10px;display:flex;flex-direction:column;gap:8px}.env-item{display:grid;grid-template-columns:10px 96px 1fr;gap:8px;align-items:center;font-size:12px;color:#36556c}.env-dot{width:8px;height:8px;border-radius:999px;display:inline-block}.env-dot.ok{background:#11a85a}.env-dot.bad{background:#d6483e}.env-name{font-weight:700}.env-detail{color:#4f7189;word-break:break-all}.toast-wrap{position:fixed;top:60px;right:14px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{min-width:220px;max-width:360px;border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;box-shadow:0 8px 16px #14487029}.toast-info{background:#eaf6ff;color:#1e6a9b;border:1px solid #cde8fb}.toast-success{background:#e9f9f0;color:#1f7d51;border:1px solid #c8edd9}.toast-error{background:#fff1f0;color:#c23f3c;border:1px solid #ffd9d7}.page{min-height:100vh;padding:84px 20px 20px;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:16px}.history-wrap{width:min(1100px,100%)}.left,.right{display:flex;flex-direction:column;gap:14px;width:min(1100px,100%)}.task-status-page{width:min(760px,100%)}.task-status-card{display:flex;flex-direction:column;gap:14px}.task-ring-wrap{display:flex;justify-content:center;align-items:center;padding:10px 0}.task-ring{width:180px;height:180px;border-radius:50%;display:flex;align-items:center;justify-content:center}.task-ring-inner{width:132px;height:132px;border-radius:50%;background:#fff;border:1px solid #d7e8f8;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#24577a}.task-status-meta{display:grid;grid-template-columns:1fr;gap:6px;padding:10px 12px;border:1px solid #deecf9;border-radius:12px;background:#f8fcff;color:#315a76}.card{background:#fff;border-radius:18px;border:1px solid #dce9f5;box-shadow:0 10px 24px #28699c14;padding:16px}.task-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:10px}.task-card-mini{border:1px solid #e2edf5;border-radius:12px;padding:12px;background:#fafdff;display:flex;flex-direction:column;gap:8px;font-size:12px}.task-card-mini .task-id{font-family:ui-monospace,monospace;font-size:11px;color:#4a6d82;word-break:break-all}.task-card-mini .task-meta{color:#5a7a90;line-height:1.4}.task-card-mini .task-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.task-status-pill{display:inline-flex;align-items:center;margin-left:6px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:700}.task-status-queued{color:#1f6a9b;background:#eaf6ff;border:1px solid #cde8fb}.task-status-processing{color:#236896;background:#edf7ff;border:1px solid #d0e8fb}.task-status-success{color:#1f7d51;background:#e9f9f0;border:1px solid #c8edd9}.task-status-failed{color:#c23f3c;background:#fff1f0;border:1px solid #ffd9d7}.task-status-cancelled{color:#7a5a1f;background:#fff8e9;border:1px solid #ffe8b3}.task-card-mini button.danger{border-color:#f0c4c2;color:#b8322d}.queue-hint{font-size:12px;color:#3b6c8b;margin-top:8px;padding:8px 10px;background:#f0f7fc;border-radius:10px;border:1px solid #d4e8f7}.section-title{font-size:13px;font-weight:700;color:#3b6c8b;margin:6px 0 10px;letter-spacing:.2px}.card-title{display:flex;align-items:center;gap:10px;margin-bottom:12px}.card-title .icon{width:30px;height:30px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#eaf6ff}.card-title h2{margin:0;font-size:32px;letter-spacing:.5px}.top-actions{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.top-actions.compact{margin-bottom:8px}.audio-settings{display:flex;flex-direction:column;gap:10px;background:#fbfdff;border:1px solid #e5eff8;border-radius:14px;padding:10px}.setting-row{display:grid;grid-template-columns:100px 1fr 78px;align-items:center;gap:10px}.setting-row label{color:#35586f;font-weight:600;font-size:13px}.page input:not([type=range]):not([type=checkbox]):not([type=color]):not([type=file]),.page select,.page textarea{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid #dce9f5;padding:8px 10px;background:#fff;color:#284f68}.page input:not([type=range]):not([type=checkbox]):not([type=color]):not([type=file]):focus,.page select:focus,.page textarea:focus{border-color:#8bc7ee;box-shadow:0 0 0 3px #08a8ff1f;outline:none}.setting-row select,.setting-row input:not([type=range]):not([type=checkbox]){width:100%;border-radius:10px;border:1px solid #dce9f5;padding:8px 10px;background:#fff}.value-text{text-align:right;color:#3d6a86;font-weight:700;font-size:12px}.audio-preview{width:100%}.tts-ref-dropdown{position:relative;width:100%}.tts-ref-trigger{width:100%;border:1px solid #dce9f5;border-radius:10px;padding:8px 10px;background:#fff;display:flex;justify-content:space-between;align-items:center;cursor:pointer;color:#284f68;font-weight:600}.tts-ref-menu{position:absolute;z-index:30;top:calc(100% + 6px);left:0;right:0;max-height:260px;overflow-y:auto;border:1px solid #dce9f5;border-radius:10px;background:#fff;box-shadow:0 8px 20px #28699c1f;padding:6px}.tts-ref-item{display:flex;align-items:center;gap:8px;padding:4px}.tts-ref-item-main{flex:1;border:none;background:#f6fbff;border-radius:8px;padding:8px 10px;text-align:left;cursor:pointer;color:#2e5771}.tts-ref-play-btn{border:none;border-radius:8px;background:#eaf6ff;color:#0f679b;font-size:12px;font-weight:700;padding:8px 10px;cursor:pointer}.tts-ref-play-btn:disabled{opacity:.5;cursor:not-allowed}.meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.badge{font-size:12px;padding:6px 10px;border-radius:999px;background:#f2f8ff;border:1px solid #dbeaf7;color:#2b5d7f}.row{display:grid;grid-template-columns:90px 1fr 54px;align-items:center;gap:10px;margin-top:10px}.row-subhint{margin:2px 0 0 100px;font-size:11px;color:#6f8a9d;font-weight:500}.row-subhint-highlight{color:#0f6fd7;font-weight:700}.setting-row-highlight{background:linear-gradient(90deg,#2f96ff14,#2f96ff05);border-radius:10px;padding:6px 8px}.grid-two input:not([type=range]):not([type=checkbox]):not([type=color]),.grid-two select{width:100%;border-radius:10px;border:1px solid #dce9f5;padding:8px 10px;background:#fff}.grid-two input[type=checkbox]{width:18px;height:18px;accent-color:#08a8ff}.grid-two input[type=color]{width:100%;height:36px;border-radius:10px;border:1px solid #dce9f5;background:#fff;padding:2px}.grid-two hr{margin:10px 0}hr{border:none;border-top:1px solid #e4eef7;margin:14px 0}.row label{color:#35586f;font-weight:600;font-size:13px}.hint{text-align:right;color:#3d6a86;font-weight:700}.error{margin-top:8px;color:#d73b39;font-size:12px;font-weight:600}.mask-meta{margin-top:8px;font-size:12px;color:#4f7088;background:#f5faff;border:1px solid #deecf9;border-radius:10px;padding:8px 10px}.preview-wrap{margin-top:10px;position:relative;border:1px solid #deecf9;border-radius:12px;overflow:hidden;background:#0f1720}.preview-img{width:100%;display:block;max-height:320px;object-fit:contain}.mask-overlay{position:absolute;left:0;right:0;border:1px solid rgba(0,195,255,.55);background:#10202c29;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);cursor:move;pointer-events:none}.mask-overlay{pointer-events:auto}.mask-handle{position:absolute;left:0;right:0;height:3px;background:#00c3ffd9;border:none;cursor:ns-resize;z-index:3}.script-box{margin-top:14px;border:1px solid #e2edf7;background:#fbfdff;border-radius:14px;padding:12px}.script-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.ghost.small{padding:8px 12px;font-size:13px}.script-pre{margin:0;max-height:260px;overflow:auto;font-size:12px;line-height:1.4}.task{margin-top:14px;padding:12px;border-radius:14px;border:1px solid #e2edf7;background:#fbfdff}.task-row{display:flex;justify-content:space-between;gap:10px;font-size:13px;color:#35586f;margin-bottom:10px}.task-row-sub{font-size:12px;color:#4a6f89;margin-bottom:8px}.bar{height:10px;background:#e9f2fb;border-radius:999px;overflow:hidden}.bar-inner{height:100%;background:linear-gradient(90deg,#08a8ff,#027bc8)}.result{margin-top:10px}.result a{color:#067cc9;font-weight:700;text-decoration:none}.bottom-actions{width:min(1100px,100%);margin-top:4px;display:flex;flex-direction:column;gap:12px}.render-btn{width:100%;height:48px;font-size:16px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-loading-dot{width:14px;height:14px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;display:inline-block;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.task-bottom-card{margin-top:0}.ghost,.primary{border:none;border-radius:12px;padding:11px 16px;font-size:15px;font-weight:700;cursor:pointer}.ghost{background:#eff6fb;color:#0f679b}.ghost:disabled{opacity:.5;cursor:not-allowed}.primary{width:100%;margin-top:12px;background:linear-gradient(90deg,#08a8ff,#027bc8);color:#fff}.primary.danger{background:linear-gradient(90deg,#ff6e66,#dd3f34)}.material-list{display:flex;flex-direction:column;gap:14px}.material-card-list{flex-direction:row;flex-wrap:wrap;gap:12px}.material-upload-card{width:180px;border:1px solid #d8e8f6;border-radius:14px;background:#fafdff;padding:10px;display:flex;flex-direction:column;gap:8px}.material-upload-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.material-card-core{width:100%;height:120px;border:1px dashed #b6d4ea;border-radius:12px;background:#fff;color:#5a86a4;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.material-plus{font-size:44px;line-height:1;font-weight:300}.material-name{font-size:12px;color:#2f5f7f;font-weight:700;word-break:break-all}.material-name-center{font-size:12px;color:#2f5f7f;font-weight:700;max-width:100%;text-align:center;line-height:1.4;padding:0 8px;word-break:break-all}.material-picked-content{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%}.material-video-icon{font-size:30px;line-height:1}.material-slot{border:1px solid #e2edf7;border-radius:14px;padding:12px;background:#fbfdff}.material-slot-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.material-slot-label{font-size:13px;font-weight:700;color:#2d5a78}.material-remove{flex-shrink:0}.material-remove-icon{width:22px;height:22px;border:none;border-radius:999px;background:#ef4a43;color:#fff;font-size:16px;line-height:1;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.material-remove-icon:hover{background:#d73932}.add-material-btn{width:100%;justify-content:center;border-style:dashed;border-color:#b8d4ea;color:#0f679b;font-weight:600}.merge-actions{display:flex;flex-direction:column;gap:8px;align-items:stretch}.merge-ok{font-size:12px;color:#1f7d51;font-weight:600}.frame-controls{display:grid;grid-template-columns:120px 1fr auto auto auto;gap:8px;align-items:center;margin-bottom:10px}.frame-controls label{color:#35586f;font-size:12px;font-weight:700}.text-block-list{display:flex;flex-direction:column;gap:10px}.text-block-card{border:1px solid #e5eff8;background:#fbfdff;border-radius:14px;padding:10px}.text-block-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.inline-slider{display:flex;align-items:center;gap:10px}.inline-slider input[type=range]{flex:1}.text-style-row{display:flex;align-items:center;gap:14px;flex-wrap:nowrap}.text-style-item{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.text-style-item span{color:#35586f;font-size:12px;font-weight:600}.text-style-item input[type=color]{width:34px;min-width:34px;height:26px;padding:0;border:1px solid #d2e1ef;border-radius:8px;background:#fff}.text-style-stroke-width{flex:1;min-width:280px}.text-style-stroke-width input[type=range]{flex:1}.preview-wrap{position:relative}.text-overlay{position:absolute;left:0;width:100%;padding:0 12px;text-align:center;pointer-events:none;text-shadow:0 2px 10px rgba(0,0,0,.55);font-weight:800}.subtitle-preview-overlay{position:absolute;left:50%;width:auto;max-width:92%;padding:0;text-align:center;transform:translate(-50%,-50%);pointer-events:none;font-weight:800;line-height:1.2;text-shadow:0 2px 12px rgba(0,0,0,.8);z-index:20;white-space:nowrap}.block-hint{margin:0;line-height:1.55;font-size:12px;color:#4a6d82}.srt-editor{width:100%;min-height:360px;border-radius:14px;border:1px solid #e2edf7;background:#fbfdff;padding:14px;resize:vertical;font-size:15px}.srt-editor-compact{min-height:140px;font-size:13px}.grid-two{display:grid;grid-template-columns:120px 1fr;gap:10px 12px;align-items:center;background:#fbfdff;border:1px solid #e5eff8;border-radius:14px;padding:10px}select,input[type=range]{width:100%}.hidden-input{display:none}.muted{color:#5c7488}
