:root{--bg:#f4f6fb;--panel:#fff;--line:#e8edf5;--text:#1f2937;--muted:#6b7280;--purple:#9b72e6;--green:#10b981;--danger:#ef4444}[data-theme=dark]{--bg:#111111;--panel:#232323;--line:#333333;--text:#e0e0e0;--muted:#888888;--purple:#b48ef0;--green:#34d399;--danger:#f87171}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,PingFang SC,Microsoft YaHei,system-ui,sans-serif;background:var(--bg);color:var(--text)}.app{height:100vh;display:grid;grid-template-columns:320px 1fr;gap:12px;padding:7px 12px 12px;transition:grid-template-columns .3s cubic-bezier(.4,0,.2,1),gap .3s cubic-bezier(.4,0,.2,1)}.app.canvas-sidebar-collapsed{grid-template-columns:0px 1fr;gap:0px}.left-panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:12px;transition:width .3s cubic-bezier(.4,0,.2,1),padding .3s cubic-bezier(.4,0,.2,1),opacity .25s ease,border-width .3s ease,margin-right .3s ease;width:320px;overflow:visible}.left-panel.canvas-collapsed{width:0!important;min-width:0!important;padding:14px 0!important;opacity:0!important;border-width:0!important;overflow:hidden!important;pointer-events:none!important;margin-right:-12px!important}.brand{font-weight:700;font-size:15px;border-left:3px solid var(--green);padding-left:8px}.mode-tabs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.mode-tab{border:1px solid var(--line);background:#fafbff;border-radius:8px;padding:9px 10px;font-weight:700;cursor:pointer}.mode-tab.active{color:var(--green);border-color:#b5e8d4;background:#f0fdf8}.block{border:1px solid var(--line);border-radius:8px;padding:10px;background:#fff}.block.row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.image2-card-title{font-size:13px;font-weight:700;color:#374151;margin-bottom:10px}.image2-field-row{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.image2-size-inputs{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}.image2-size-inputs span{font-size:13px;color:#9ca3af;text-align:center}.image2-size-inputs input{width:100%;border:1px solid var(--line);border-radius:6px;padding:8px;font-size:12px;outline:none;background:#fff}.image2-size-inputs input:focus{border-color:#7aa8ff}.image2-hint-ok{font-size:11px;color:#10b981}.image2-hint-error{font-size:11px;color:#ef4444}.image2-preset-wrap{display:flex;flex-wrap:wrap;gap:6px}.image2-preset-pill{border:1px solid #e5e7eb;background:#fff;color:#374151;border-radius:999px;padding:5px 10px;font-size:12px;line-height:1;cursor:pointer}.image2-preset-pill.active{border-color:#86b7ff;background:#f3f8ff;color:#1f4fa3}.block-title{font-size:12px;color:var(--muted);margin-bottom:8px}.block-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.upload-head .block-title{margin-bottom:0}.upload-head .upload-btn{margin-left:auto}.upload-btn{display:inline-block;padding:7px 10px;font-size:12px;border:1px solid var(--line);border-radius:6px;cursor:pointer;background:#fff}#refUpload,#targetUpload{display:none}.thumbs{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.thumb-wrap{position:relative}.thumb{width:38px;height:38px;border:1px solid var(--line);border-radius:6px;object-fit:cover}.thumb-del{position:absolute;right:-6px;top:-6px;width:16px;height:16px;border-radius:50%;border:1px solid #fff;background:#111;color:#fff;font-size:10px;line-height:14px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}.thumb-del svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}textarea{width:100%;min-height:120px;resize:vertical;border:1px solid var(--line);border-radius:6px;padding:8px;font-size:12px;outline:none}textarea:focus,select:focus,input:focus{border-color:#7aa8ff}select,.input-wrap input{width:100%;border:1px solid var(--line);border-radius:6px;padding:8px;font-size:12px;outline:none;background:#fff}.polish-btn{border:1px solid #7ed7a8;background:#d9f6e6;color:#0a6f3e;border-radius:8px;padding:3px 8px;font-size:12px;font-weight:700;cursor:pointer}.main-btn{margin-top:auto;border:none;background:#000;color:#fff;border-radius:8px;padding:12px;font-weight:700;cursor:pointer}.main-btn:disabled{opacity:.6;cursor:not-allowed}.block.drop-active{border-color:#86b7ff;background:#f5f9ff;box-shadow:0 0 0 2px #86b7ff33 inset}.right-panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;display:flex;flex-direction:column;overflow:hidden}.top-bar{height:54px;border-bottom:1px solid var(--line);padding:0 14px;display:flex;align-items:center;justify-content:space-between}.top-title{font-size:14px;font-weight:700}.top-actions{position:relative;display:flex;align-items:center;gap:8px}.account-icon{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:#fff;cursor:pointer}.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:0}.icon-svg{width:17px;height:17px;fill:none;stroke:#8b8b8b;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}#noticeBtn .icon-svg{width:18px;height:18px}.icon-img{width:100%;height:100%;object-fit:cover;border-radius:50%}#accountIconBtn{overflow:hidden;padding:0}.queue-wrap{position:relative}.task-badge{position:absolute;right:-6px;top:-6px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.task-popover{position:absolute;top:42px;right:42px;width:260px;max-height:300px;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 30px #0f172a24;padding:8px;z-index:30}.charge-popover{position:absolute;top:42px;right:0;width:340px;max-height:360px;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 30px #0f172a24;padding:8px;z-index:30}.task-item{border:1px solid var(--line);border-radius:8px;padding:8px;margin-bottom:8px;display:flex;gap:8px;align-items:center}.task-item .task-main{min-width:0;flex:1}.task-del{width:22px;height:22px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;cursor:pointer;font-size:12px;line-height:1}.task-del:hover{background:#f3f4f6;color:#111}.task-item img{width:30px;height:30px;border-radius:6px;object-fit:cover}.task-item .name{margin:0;font-size:12px;font-weight:700}.task-item .status{margin:2px 0 0;font-size:11px;color:#f59e0b}.charge-item{border:1px solid var(--line);border-radius:8px;padding:8px;margin-bottom:8px;background:#fff}.charge-item .name{margin:0;font-size:12px;font-weight:700;color:#111827}.charge-item .status{margin:2px 0 0;font-size:11px;color:#6b7280}.account-popover{position:absolute;top:44px;right:0;width:280px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 30px #0f172a24;padding:12px;z-index:20}.hidden{display:none!important}.popover-title{font-size:13px;font-weight:700;margin-bottom:10px}.field{margin-bottom:10px}.field label{display:block;margin-bottom:6px;font-size:12px;color:var(--muted)}.id-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.input-wrap{position:relative}.input-wrap input{padding-right:36px;text-align:center;font-family:ui-monospace,monospace;font-weight:700;color:#4b5563}#toggle-id-visibility-btn{position:absolute;right:7px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;color:#9ca3af;width:24px;height:24px;padding:0}#toggle-id-visibility-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}.mini-btn{border:1px solid var(--line);background:#fff;border-radius:6px;padding:8px 10px;font-size:12px;cursor:pointer;font-weight:700}.id-mini{padding:8px 9px;font-size:11px;white-space:nowrap}.balance-box{border:1px solid var(--line);border-radius:8px;padding:10px;font-size:12px;color:var(--muted)}.points{margin-top:6px;display:flex;align-items:center;justify-content:center;gap:4px}.points b{font-size:24px;color:#f59e0b}.popover-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px}#recharge-btn{background:#000;border-color:#000;color:#fff}.card-grid{flex:1;padding:12px;column-count:5;column-gap:10px;overflow-y:auto;position:relative}.card{display:inline-block;width:100%;margin:0 0 10px;border-radius:12px;overflow:hidden;background:#fff;break-inside:avoid;vertical-align:top}.card.selected-card{outline:2px solid #3b82f6;outline-offset:2px}.card-selection-marquee{position:fixed;border:1px solid #3b82f6;background:#3b82f61f;z-index:1500;pointer-events:none}.card-image-wrap{position:relative}.card img{width:100%;height:auto;display:block;background:#f8fafc;cursor:zoom-in}.card-overlay-top,.card-overlay-bottom,.card-top-left-badge{opacity:0;transition:opacity .2s;pointer-events:none}.card:hover .card-overlay-top,.card:hover .card-overlay-bottom,.card:hover .card-top-left-badge{opacity:1;pointer-events:auto}.card-overlay-top{position:absolute;top:10px;right:10px;display:flex;gap:8px}.card-top-left-badge{position:absolute;top:10px;left:10px;max-width:calc(100% - 90px);padding:4px 8px;border-radius:999px;background:#00000094;color:#fff;font-size:11px;font-weight:700;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-icon-btn{width:30px;height:30px;border-radius:8px;border:1px solid rgba(0,0,0,.15);background:#ffffffeb;cursor:pointer;font-size:12px;display:inline-flex;align-items:center;justify-content:center}.card-icon-btn svg{width:16px;height:16px;fill:none;stroke:#111;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.card-overlay-bottom{position:absolute;left:10px;right:10px;bottom:10px;color:#fff;font-size:12px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.6);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card.grouped-card{box-shadow:0 0 0 2px color-mix(in oklab,var(--group-color) 28%,white) inset}.card.grouped-card .card-image-wrap:before{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--group-color);z-index:1}.group-collage{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;background:#e5e7eb}.group-collage-img{width:100%;height:100%;object-fit:cover;display:block;background:#f3f4f6}.group-collapsed-card .card-image-wrap{aspect-ratio:1/1;background:#f8fafc}.group-collapsed-card img{width:100%;height:100%;object-fit:cover}.group-stack-badge{position:absolute;right:10px;bottom:10px;min-width:44px;height:24px;padding:0 8px;border-radius:999px;background:#111827b8;color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.pending-card{border-radius:20px;overflow:hidden;background:#20252a}.pending-blur{position:relative;width:100%;aspect-ratio:var(--pending-ratio,1 / 1);border-radius:20px;overflow:hidden;background:radial-gradient(circle at 70% 15%,#6f757b 0,#30363b 28%,#1f252a 55%,#565d63);filter:saturate(.9);animation:pendingPulse 1.5s ease-in-out infinite}.pending-del{position:absolute;right:10px;top:10px;width:24px;height:24px;border:1px solid rgba(255,255,255,.35);border-radius:8px;background:#00000073;color:#fff;display:inline-flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .16s ease;cursor:pointer;z-index:3}.pending-card:hover .pending-del{opacity:1;pointer-events:auto}.pending-shimmer{position:absolute;top:-30%;right:-30%;bottom:-30%;left:-30%;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.18) 45%,transparent 60%);animation:pendingMove 1.8s linear infinite}.pending-img{position:absolute;left:18px;top:18px;color:#ffffffb3;font-size:22px;z-index:2}.pending-percent{position:absolute;right:16px;top:16px;color:#ffffffbf;font-size:20px;font-weight:700;z-index:2;pointer-events:none}@keyframes pendingPulse{0%,to{opacity:.78}50%{opacity:1}}@keyframes pendingMove{to{transform:translate(55%)}}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000db;z-index:20000;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.lightbox img{max-width:92vw;max-height:92vh;border-radius:8px;object-fit:contain}.editor-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000db;z-index:1200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.editor-toolbar{height:52px;width:fit-content;max-width:96vw;padding:0 8px;border-radius:26px;background:#2b2b2b;border:1px solid #3a3b40;display:grid;grid-template-columns:auto auto auto;justify-content:center;align-items:center;column-gap:10px;box-shadow:0 12px 30px #00000059}.tb-left,.tb-right{display:flex;align-items:center}.tb-right{justify-content:flex-end}.tb-center{display:flex;align-items:center;justify-content:center;gap:10px}.tb-btn{width:28px;height:28px;border:none;border-radius:8px;background:transparent;color:#f0f0f0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:background .16s ease,box-shadow .16s ease}.tb-btn:hover,.tb-btn.active{background:#4a4a4a;box-shadow:inset 0 0 0 1px #ffffff14}.tb-btn svg{width:16px;height:16px;fill:none;stroke:#f0f0f0;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.tb-btn.active{color:#fff}.tb-btn.active svg{stroke:#fff}.tb-text-btn{height:28px;border:none;border-radius:8px;background:transparent;color:#f0f0f0;cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:0 6px;font-size:12px;font-weight:600;transition:background .16s ease,box-shadow .16s ease}.tb-text-btn:hover,.tb-text-btn.active{background:#4a4a4a;box-shadow:inset 0 0 0 1px #ffffff14}.tb-text-btn svg{width:16px;height:16px;fill:none;stroke:#f0f0f0;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.tb-divider{width:1px;height:20px;background:#4a4b50}.color-palette{display:flex;gap:6px}.color-dot{width:16px;height:16px;border-radius:4px;border:1px solid rgba(255,255,255,.35);background:var(--c);cursor:pointer;padding:0}.color-dot.active{outline:2px solid #fff}.slider-wrap{display:flex;align-items:center;gap:6px}.slider-dot{width:8px;height:8px;border-radius:50%;background:#fff;display:inline-block}#edSize{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:88px;height:2px;background:#7a7d85;border-radius:2px}#edSize::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;border:none;cursor:pointer}.tb-text-btn.loading{opacity:.9}.tb-text-btn .spin{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.editor-stage-wrap{position:relative;width:92vw;max-width:1240px;max-height:68vh;display:flex;justify-content:center;align-items:flex-start}.editor-stage{position:relative;margin:0 auto}.editor-stage canvas{position:absolute;left:0;top:0}.editor-stage #edBg{position:relative}.ed-text-panel{position:absolute;right:0;top:50%;transform:translateY(-50%);width:260px;max-height:62vh;overflow:auto;background:#3a3a3a;border-radius:14px;padding:10px;box-shadow:0 8px 24px #00000059}.ed-line{display:grid;grid-template-columns:4px 1fr;gap:8px;align-items:center;margin-bottom:8px}.ed-line i{width:4px;height:16px;background:#10b981;border-radius:999px}.ed-line input{width:100%;border:1px solid #4a4a4a;border-radius:8px;padding:8px 10px;background:#595959;color:#fff;font-size:12px}.ed-text-panel.hidden{display:none!important}.editor-prompt{width:1000px;max-width:94vw;background:#2b2b2b;border:1px solid #3d3f46;border-radius:14px;padding:12px;position:relative;box-shadow:0 14px 36px #0000006b;transition:width .28s ease,padding .28s ease,border-radius .28s ease,transform .28s ease}.editor-prompt textarea{background:#2b2b2b;color:#e5e7eb;border:1px solid #43454d;min-height:76px;padding:14px;border-radius:12px;transition:min-height .28s ease,border-radius .28s ease,padding .28s ease}.editor-prompt.collapsed{width:520px;padding:8px 12px;border-radius:18px}.editor-prompt.collapsed textarea{min-height:54px;padding:14px;border-radius:16px}.editor-prompt.collapsed .editor-prompt-bottom{height:0;opacity:0;overflow:hidden;pointer-events:none;margin:0}.editor-prompt-bottom{height:44px;display:flex;align-items:center;justify-content:space-between;opacity:1;transition:height .28s ease,opacity .22s ease,margin .28s ease}.editor-attach-area{display:flex;align-items:center;gap:10px;min-width:0}.ed-attach-btn{width:34px;height:34px;border:none;background:transparent;color:#e5e7eb;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.ed-attach-btn svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.ed-attach-thumbs{display:flex;align-items:center;gap:8px;overflow:hidden}.ed-attach-thumb-wrap{position:relative;width:34px;height:34px}.ed-attach-thumb-wrap img{width:34px;height:34px;border-radius:8px;object-fit:cover;border:1px solid #4a4a4a}.ed-attach-thumb-wrap button{position:absolute;right:-5px;top:-5px;width:14px;height:14px;border-radius:50%;border:1px solid #111;background:#000;color:#fff;font-size:10px;line-height:12px;padding:0;cursor:pointer}.editor-generate-area{display:flex;align-items:center;gap:12px}.ed-quality{height:40px;min-width:54px;width:54px;border:1px solid #3d3f46;border-radius:10px;color:#d1d5db;background:#2b2b2b;display:inline-flex;align-items:center;justify-content:center;font-weight:700;text-align:center;padding:0 8px;outline:none;cursor:pointer}#edModel,#edTextModel{min-width:96px;width:96px;text-align:left;padding:0 10px}.editor-prompt button#edGenerate{height:40px;background:#000;color:#fff;border:1px solid #1f1f1f;border-radius:10px;padding:0 22px;font-weight:700;cursor:pointer}#edAttachUpload{display:none}@media (max-width:1400px){.card-grid{column-count:4}}@media (max-width:1200px){.card-grid{column-count:3}.editor-toolbar{max-width:94vw;grid-template-columns:auto auto auto;justify-content:center;column-gap:10px;padding:0 6px}}@media (max-width:960px){.app{grid-template-columns:1fr;height:auto}.left-panel{order:2}.right-panel{min-height:70vh}.card-grid{column-count:2}}@media (max-width:960px){html,body{height:auto;min-height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}body.workspace-open{overflow-y:auto}.workspace-app:not(.hidden){height:auto;min-height:calc(100vh - var(--shared-top-h))}.project-hub{height:auto;min-height:calc(100vh - var(--shared-top-h));overflow:visible}.card-grid{overflow:visible;max-height:none}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}*{scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.prompt-dialog{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1300;display:flex;align-items:center;justify-content:center;padding:16px}.prompt-dialog.hidden{display:none}.prompt-dialog-panel{width:min(760px,92vw);max-height:80vh;overflow:hidden;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 18px 40px #00000040;display:flex;flex-direction:column}.prompt-dialog-head{height:48px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid #eef2f7}.prompt-dialog-close{border:none;background:transparent;font-size:18px;cursor:pointer;color:#6b7280}.prompt-dialog-text{margin:0;padding:14px;overflow:auto;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.6;color:#111827;max-height:calc(80vh - 108px)}.prompt-dialog-copy{margin:0 14px 14px;border:none;background:#111;color:#fff;border-radius:8px;padding:10px 12px;font-weight:700;cursor:pointer}.oc-native-select{position:absolute!important;opacity:0!important;pointer-events:none!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;height:100%!important}.oc-select{position:relative;width:100%}.oc-select-btn{width:100%;border:1px solid var(--line);border-radius:12px;background:#fff;padding:8px 34px 8px 10px;font-size:12px;line-height:1.2;color:var(--text);text-align:left;cursor:pointer;position:relative}.oc-select-btn:after{content:"";position:absolute;right:11px;top:50%;width:7px;height:7px;border-right:1.5px solid #9ca3af;border-bottom:1.5px solid #9ca3af;transform:translateY(-65%) rotate(45deg);transition:transform .16s ease}.oc-select.open .oc-select-btn{border-bottom-left-radius:10px;border-bottom-right-radius:10px}.oc-select.open .oc-select-btn:after{transform:translateY(-35%) rotate(225deg)}.oc-select.open-up .oc-select-btn{border-top-left-radius:10px;border-top-right-radius:10px}.oc-select-menu{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 24px #0f172a1f;padding:4px;max-height:260px;overflow:auto;z-index:80;display:none}.oc-select.open-up .oc-select-menu{top:auto;bottom:calc(100% + 6px)}.oc-select.open .oc-select-menu{display:block}.oc-select-option{padding:8px 10px;border-radius:8px;font-size:12px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.oc-select-option:hover{background:#f3f6fb}.oc-select-option.active{background:#eef4ff;color:#1f4fa3}.editor-generate-area .oc-select{width:auto}.editor-generate-area .oc-select--edModel{min-width:104px}.editor-generate-area .oc-select--edQuality{min-width:72px}.editor-generate-area .oc-select-btn{height:40px;border:1px solid #3d3f46;border-radius:12px;background:#2b2b2b;color:#d1d5db;padding:0 30px 0 12px;font-weight:700;font-size:12px;display:flex;align-items:center}.editor-generate-area .oc-select-btn:after{border-right-color:#d1d5db;border-bottom-color:#d1d5db;right:12px}.editor-generate-area .oc-select-menu{background:#2f3137;border-color:#3d3f46;box-shadow:0 12px 24px #00000059}.editor-generate-area .oc-select-option{color:#e5e7eb}.editor-generate-area .oc-select-option:hover{background:#3a3d45}.editor-generate-area .oc-select-option.active{background:#4a4f59;color:#fff}.ed-text-panel .oc-select{width:100%}.ed-text-panel .oc-select-btn{height:36px;border:1px solid #4a4a4a;border-radius:10px;background:#3a3a3a;color:#e5e7eb;padding:0 30px 0 12px;font-weight:700;font-size:12px;display:flex;align-items:center}.ed-text-panel .oc-select-btn:after{border-right-color:#cfd3da;border-bottom-color:#cfd3da;right:12px}.ed-text-panel .oc-select-menu{top:calc(100% + 6px);background:#2f3238;border:1px solid #454a53;border-radius:12px;box-shadow:0 12px 24px #00000059;padding:4px}.ed-text-panel .oc-select-option{color:#e5e7eb;border-radius:8px}.ed-text-panel .oc-select-option:hover{background:#3a3f48}.ed-text-panel .oc-select-option.active{background:#5a616d;color:#fff}.oc-select-menu--ed-text-model{background:#2f3238;border:1px solid #454a53;box-shadow:0 12px 24px #00000059}.oc-select-menu--ed-text-model .oc-select-option{color:#e5e7eb;border-radius:8px}.oc-select-menu--ed-text-model .oc-select-option:hover{background:#3a3f48}.oc-select-menu--ed-text-model .oc-select-option.active{background:#5a616d;color:#fff}.suite-modules-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.suite-module-card{display:block;border:1px solid #e5e7eb;border-radius:10px;padding:12px;background:#fff;cursor:pointer;transition:all .16s ease;position:relative}.suite-module-card:hover{border-color:#d7dce5;background:#fafbff}.suite-module-checkbox{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.suite-module-content{pointer-events:none;opacity:.85;transition:opacity .16s}.suite-module-title{font-size:13px;font-weight:700;color:#111827;margin-bottom:4px}.suite-module-desc{font-size:11px;color:#6b7280}.mode-tabs-segment{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:6px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:10px;margin:2px 0 4px}.mode-tabs-segment .mode-tab{height:40px;border:1px solid transparent;border-radius:10px;background:transparent;color:#6b7280;font-weight:700;font-size:13px;line-height:1;letter-spacing:.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .16s ease}.mode-tabs-segment .mode-tab.active{background:#fff;border-color:#e5e7eb;color:#2563eb;box-shadow:0 1px #1118270d}.polish-btn{background:#fff!important;border:1px solid #d1d5db!important;color:#2563eb!important}.mode-tabs-segment .mode-tab:not(.active):hover{background:#f3f4f6;color:#4b5563}.image2-size-inputs input.image2-auto{background:#f3f4f6;color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed;text-transform:lowercase}.suite-module-card:has(.suite-module-checkbox:checked){border-color:#3b82f6!important;background:#eff6ff!important;box-shadow:0 0 0 1px #3b82f6!important}.suite-module-card:has(.suite-module-checkbox:checked) .suite-module-content{opacity:1!important}.suite-module-card:has(.suite-module-checkbox:checked) .suite-module-title{color:#1d4ed8!important}.suite-module-card:has(.suite-module-checkbox:checked) .suite-module-desc{color:#1d4ed8!important}@media (max-width:960px){body[data-mode=suite] .app{grid-template-columns:1fr;height:auto}body[data-mode=suite] .left-panel{order:2;max-height:none;overflow:visible}body[data-mode=suite] .right-panel{order:1;min-height:52vh}body[data-mode=suite] .suite-modules-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){body[data-mode=suite] .app{padding:8px;gap:8px}body[data-mode=suite] .left-panel{padding:10px;gap:8px}body[data-mode=suite] .mode-tabs-segment .mode-tab{font-size:12px}body[data-mode=suite] .suite-module-card{padding:10px}}.top-bar-main,.workspace-top-main{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.workspace-project-title-wrap{display:flex;align-items:center;gap:8px;min-width:0}.workspace-project-title-wrap .top-title{margin:0;max-width:360px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.workspace-project-title-input{height:30px;min-width:96px;max-width:min(60vw,520px);padding:0 10px;border:1px solid #86b7ff;border-radius:8px;background:#fff;color:#111827;font-size:14px;font-weight:700;outline:none;width:96px}.workspace-project-title-input:focus{box-shadow:0 0 0 2px #3b82f626}.workspace-project-edit-btn{height:26px;padding:0 10px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#374151;font-size:12px;font-weight:600;cursor:pointer}.workspace-project-edit-btn:hover{border-color:#2563eb;color:#2563eb;background:#f5f9ff}.grid-hint{margin:0;padding:0;font-size:11px;line-height:1.45;color:#6b7280;flex:1;min-width:0}.top-bar{height:auto;min-height:54px}:root{--shared-top-h:64px}body:not(.workspace-open){background:var(--bg)}.shared-top-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;height:var(--shared-top-h);padding:0 20px;position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:none}.shared-top-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.hub-brand-block{display:flex;align-items:baseline;gap:10px}.hub-logo-text{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.02em}.hub-logo-sub{font-size:12px;color:var(--muted)}.hub-back-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:#fff;color:#8b8b8b;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}.hub-back-icon{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.hub-back-btn:hover{background:#f9fafb;color:#6b7280}.project-list-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.project-image-count{font-size:12px;color:#9ca3af;line-height:1;font-weight:500}.project-list-actions{display:flex;align-items:center;gap:8px}.project-list-action-btn{height:30px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#3b82f6;font-size:12px;font-weight:700;cursor:pointer;display:none}.project-list-action-btn:hover{border-color:#3b82f6;color:#2563eb;background:#f5f9ff}.shared-top-actions{display:flex;align-items:center;gap:8px;position:relative}.shared-top-actions .task-popover,.shared-top-actions .charge-popover,.shared-top-actions .account-popover{z-index:220}.project-hub{background:linear-gradient(180deg,#eef2ff,#f4f6fb 40%,#f4f6fb);height:calc(100vh - var(--shared-top-h));overflow:auto;padding:0 0 40px;box-sizing:border-box}.hub-hero{border-radius:0;overflow:hidden;margin:0;width:100%;background:#fff;border:none;min-height:420px;box-shadow:none}.hub-hero-inner{max-width:1280px;margin:0 auto;padding:84px 24px 70px;display:grid;grid-template-columns:minmax(520px,1.08fr) minmax(360px,.92fr);gap:8px;align-items:start;min-height:420px}.hub-hero-copy{max-width:700px;margin-left:0}.hub-hero-title{margin:0 0 10px;font-size:60px;line-height:1.02;font-weight:700;color:#0b1020;letter-spacing:-.028em}.hub-hero-desc{margin:0;font-size:16px;line-height:1.62;font-weight:600;color:#4b5563;max-width:760px}.hub-hero-actions{display:flex;align-items:center;gap:12px;margin-top:18px}.hub-hero-hint{margin-top:14px;font-size:12px;line-height:1.6;color:#a8b1c0;max-width:760px}.hub-hero-visual{position:relative;min-height:250px;width:420px;max-width:100%;justify-self:end}.hub-showcase-card{position:absolute;width:206px;background:#fff;border:1px solid #e8edf5;border-radius:14px;box-shadow:0 10px 24px #0f172a1f;overflow:hidden;display:block!important;cursor:pointer}.hub-showcase-card:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.hub-showcase-card .hub-showcase-img{height:170px;background:linear-gradient(140deg,#ecf3ff,#dbeafe 48%,#f5edff);background-size:cover;background-position:center;display:block!important}.hub-showcase-card.card-a{left:0;top:38px;transform:rotate(-5deg)}.hub-showcase-card.card-b{left:118px;top:10px;transform:rotate(1.5deg)}.hub-showcase-card.card-c{left:260px;top:42px;transform:rotate(6deg)}.hub-showcase-meta{padding:10px;display:block!important}.hub-showcase-title{font-size:11px;line-height:1.42;color:#1f2937;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block!important}.hub-showcase-time{display:none!important}.hub-hero-btn-primary{background:#111;color:#fff;box-shadow:none;height:44px;padding:0 28px;border-radius:13px;font-size:14px;font-weight:700;line-height:1;border:none}.hub-hero-btn-primary:hover{background:#000}.hub-hero-btn-ghost{background:#fff;color:#111;border:1px solid #d1d5db;height:44px;padding:0 28px;border-radius:13px;font-size:14px;font-weight:700;line-height:1}.hub-hero-btn-ghost:hover{background:#fff;color:#111;border-color:#c4c8cf}.project-list-section{max-width:1280px;margin:28px auto 0;padding:0 24px}.project-list-title{margin:0 0 14px;font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.01em}.project-list-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.project-card{position:relative;margin:0;padding:0;background:var(--panel);border-radius:14px;overflow:hidden;cursor:pointer;text-align:left;border:1px solid #e6ebf5;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.project-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px #0f172a1a;border-color:#d1d5db}.project-card-thumb{aspect-ratio:4/3;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.project-card-thumb img{width:100%;height:100%;object-fit:cover}.project-card-meta{padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:8px}.project-card-name{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-name-input{width:100%;height:28px;border:1px solid #86b7ff;border-radius:8px;padding:0 8px;font-size:14px;font-weight:600;color:var(--text);background:#fff;outline:none}.project-card-name-input:focus{box-shadow:0 0 0 2px #3b82f626}.project-card-sub{margin-top:6px;display:flex;align-items:center;justify-content:space-between;gap:8px}.project-card-count{font-size:12px;color:#6b7280;white-space:nowrap}.project-card-time{font-size:12px;color:var(--muted);white-space:nowrap;flex-shrink:0}.project-card-del,.project-card-rename,.project-card-download{position:absolute;top:8px;width:28px;height:28px;border-radius:8px;border:1px solid var(--line);background:#ffffffeb;color:#374151;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease;padding:0;box-shadow:0 1px 2px #0000000f}.project-card-del{right:8px}.project-card-rename{right:40px}.project-card-download{right:72px}.project-card-icon{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.project-card:hover .project-card-del,.project-card:hover .project-card-rename,.project-card:hover .project-card-download{opacity:1}.project-card-download:hover,.project-card-rename:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.project-card-del:hover{background:#dc2626;border-color:#dc2626;color:#fff}.project-card-new{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:205px;border:1px dashed #c4c9d4;background:#fff;color:#4b5563}.project-card-new-plus{width:64px;height:64px;border-radius:50%;border:1px dashed #c4c9d4;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:300;line-height:1;color:inherit}.project-card-new:hover{border-color:#3b82f6;color:#2563eb;background:#e7f0ff}.project-card-new:hover .project-card-new-plus{border-color:#3b82f6}.project-card-new-text{font-size:14px;font-weight:700}.project-card-new-sub{font-size:12px;color:#6b7280}.workspace-app:not(.hidden){height:calc(100vh - var(--shared-top-h));box-sizing:border-box}.notice-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a85;z-index:1350;display:flex;align-items:center;justify-content:center;padding:20px 16px}.notice-popup-overlay.hidden{display:none!important}.notice-popup-panel{width:min(480px,94vw);max-height:min(78vh,620px);overflow:hidden;background:#fff;border-radius:14px;border:1px solid #e5e7eb;box-shadow:0 22px 55px #0f172a47;display:flex;flex-direction:column}.notice-popup-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px 10px;border-bottom:1px solid #eef2f7}.notice-popup-title{margin:0;font-size:16px;font-weight:700;color:#111827;line-height:1.35;flex:1;min-width:0}.notice-popup-time{margin:0;padding:0 16px 8px;font-size:11px;color:#9ca3af}.notice-popup-body{padding:8px 16px 12px;overflow:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch}.notice-popup-item{padding-bottom:4px}.notice-popup-item+.notice-popup-item{border-top:1px solid #eef2f7;margin-top:14px;padding-top:14px}.notice-popup-actions{padding:10px 16px 16px;border-top:1px solid #f3f4f6}.notice-popup-ok{width:100%;border:none;background:#111827;color:#fff;border-radius:10px;padding:11px 14px;font-size:13px;font-weight:700;cursor:pointer}.notice-popup-ok:hover{background:#0f172a}.disclaimer-fab{position:fixed;left:16px;bottom:16px;z-index:1325;width:37px;height:37px;border-radius:50%;border:1px solid #e5e7eb;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.disclaimer-fab svg{width:17px;height:17px;fill:none;stroke:#8b8b8b;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.disclaimer-fab:hover{border-color:#cbd5e1;box-shadow:0 14px 30px #0f172a29}.disclaimer-panel{width:min(760px,94vw);max-height:min(82vh,760px);overflow:hidden}.disclaimer-body{padding:12px 16px 16px;overflow:auto;display:flex;flex-direction:column;min-height:0;max-height:calc(min(82vh,760px) - 120px)}.disclaimer-text{margin:0;white-space:pre-wrap;word-break:break-word;font-family:inherit;font-size:13px;line-height:1.72;color:#111827;overflow:visible;background:#f8fafc;border:1px solid #eef2f7;border-radius:12px;padding:14px;flex:0 0 auto}@media (max-width:960px){html,body{height:auto!important;min-height:100%!important;overflow-y:auto!important;overflow-x:hidden;-webkit-overflow-scrolling:touch}.workspace-app:not(.hidden){height:auto!important;min-height:calc(100vh - var(--shared-top-h))!important}.app{height:auto!important;min-height:calc(100vh - var(--shared-top-h))!important}.right-panel{overflow:visible!important}.card-grid{overflow:visible!important;max-height:none!important}.project-hub{height:auto!important;min-height:calc(100vh - var(--shared-top-h))!important;overflow:visible!important}}#recharge-btn:disabled,#recharge-btn.is-disabled{background:#e5e7eb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed;opacity:1;pointer-events:none}#admin-entry-btn{background:#111827;border-color:#111827;color:#fff}#admin-entry-btn:hover{background:#0f172a}.admin-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1400;display:flex;align-items:center;justify-content:center;padding:16px}.admin-panel.hidden{display:none!important}.admin-panel-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a8c}.admin-panel-shell{position:relative;width:min(960px,96vw);max-height:90vh;background:#fff;border-radius:14px;border:1px solid #e5e7eb;box-shadow:0 24px 60px #0f172a40;display:flex;flex-direction:column;overflow:hidden}.admin-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #eef2f7}.admin-panel-title{font-size:16px}.admin-panel-sub{margin:4px 0 0;font-size:12px;color:#6b7280}.admin-panel-close{border:none;background:transparent;font-size:18px;cursor:pointer;color:#6b7280}.admin-tabs{display:flex;gap:6px;padding:10px 12px;border-bottom:1px solid #eef2f7;overflow-x:auto}.admin-tab{border:1px solid #e5e7eb;background:#f9fafb;color:#374151;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.admin-tab.active{background:#111827;border-color:#111827;color:#fff}.admin-panel-body{padding:14px 16px 16px;overflow:auto;flex:1}.admin-section{margin-bottom:16px}.admin-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.admin-section-head h3{margin:0;font-size:14px}.admin-table-wrap{overflow:auto;border:1px solid #e5e7eb;border-radius:10px}.admin-table{width:100%;border-collapse:collapse;font-size:12px}.admin-table th,.admin-table td{border-bottom:1px solid #f1f5f9;padding:8px;text-align:left;vertical-align:top}.admin-table th{background:#f8fafc;color:#64748b;font-weight:700}.admin-inp{width:100%;min-width:80px;border:1px solid #d1d5db;border-radius:8px;padding:6px 8px;font-size:12px}.admin-inp-sm{min-width:90px}.admin-inp-xs{min-width:52px;width:52px}.admin-ta{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:8px;font-size:12px;resize:vertical}.admin-ta.block,.admin-inp.block{display:block;width:100%;margin:6px 0 10px}.admin-check{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#374151;white-space:nowrap}.admin-check.block{display:flex;margin:8px 0}.admin-hint{margin:8px 0 0;font-size:11px;color:#6b7280;line-height:1.5}.admin-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.admin-primary{background:#111827!important;border-color:#111827!important;color:#fff!important}.admin-link{border:none;background:transparent;color:#2563eb;cursor:pointer;font-size:12px;padding:0}.admin-link.danger{color:#dc2626}.admin-pre{margin:8px 0 0;padding:10px;background:#0f172a;color:#e2e8f0;border-radius:10px;font-size:11px;line-height:1.5;max-height:280px;overflow:auto;white-space:pre-wrap;word-break:break-word}.admin-row{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0;align-items:center}.admin-hr{border:none;border-top:1px solid #eef2f7;margin:14px 0}.admin-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.admin-stat{border:1px solid #e5e7eb;border-radius:10px;padding:12px;text-align:center;background:#f8fafc}.admin-stat b{display:block;font-size:22px;color:#111827}.admin-stat span{font-size:11px;color:#6b7280}.mini-btn.danger{color:#dc2626;border-color:#fecaca;background:#fef2f2}[data-theme=dark] body{background:var(--bg);color:var(--text)}.theme-toggle-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--panel);color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:background .16s,border-color .16s,color .16s}.theme-toggle-btn:hover{background:var(--bg);color:var(--text)}.theme-toggle-btn svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.theme-toggle-btn .icon-moon{display:none}.theme-toggle-btn .icon-sun,[data-theme=dark] .theme-toggle-btn .icon-moon{display:block}[data-theme=dark] .theme-toggle-btn .icon-sun{display:none}[data-theme=dark] .left-panel,[data-theme=dark] .right-panel,[data-theme=dark] .block,[data-theme=dark] .upload-btn,[data-theme=dark] .mini-btn,[data-theme=dark] .account-icon,[data-theme=dark] .hub-back-btn{background:var(--panel);border-color:var(--line);color:var(--text)}[data-theme=dark] .mode-tab{background:#2a2a2a;border-color:var(--line);color:var(--muted)}[data-theme=dark] .mode-tab.active{color:var(--green);border-color:#2a5c47;background:#162b22}[data-theme=dark] .mode-tabs-segment{background:#1a1a1a;border-color:var(--line)}[data-theme=dark] .mode-tabs-segment .mode-tab.active{background:#2a2a2a;border-color:var(--line);color:var(--text)}[data-theme=dark] .mode-tabs-segment .mode-tab:not(.active):hover{background:#2a2a2a;color:var(--text)}[data-theme=dark] textarea,[data-theme=dark] select,[data-theme=dark] .input-wrap input,[data-theme=dark] .image2-size-inputs input{background:#2a2a2a;border-color:var(--line);color:var(--text)}[data-theme=dark] textarea:focus,[data-theme=dark] select:focus,[data-theme=dark] .input-wrap input:focus,[data-theme=dark] .image2-size-inputs input:focus{border-color:#666}[data-theme=dark] .image2-size-inputs input.image2-auto{background:#1a1a1a;color:var(--muted);border-color:var(--line)}[data-theme=dark] .image2-card-title{color:var(--text)}[data-theme=dark] .image2-size-inputs span{color:var(--muted)}[data-theme=dark] .image2-preset-pill{border-color:var(--line);background:var(--panel);color:var(--text)}[data-theme=dark] .image2-preset-pill.active{border-color:#666;background:#2a2a2a;color:var(--text)}[data-theme=dark] .polish-btn{background:#2a2a2a!important;border-color:#444!important;color:#ccc!important}[data-theme=dark] .main-btn{background:#e0e0e0;color:#111}[data-theme=dark] .main-btn:hover{background:#fff}[data-theme=dark] .shared-top-bar{background:var(--bg)}[data-theme=dark] .hub-logo-text{color:var(--text)}[data-theme=dark] .top-bar{border-color:var(--line)}[data-theme=dark] .task-popover,[data-theme=dark] .charge-popover,[data-theme=dark] .account-popover{background:var(--panel);border-color:var(--line);box-shadow:0 12px 30px #00000080}[data-theme=dark] .task-item,[data-theme=dark] .charge-item{background:#2a2a2a;border-color:var(--line)}[data-theme=dark] .charge-item .name{color:var(--text)}[data-theme=dark] .task-del{background:#2a2a2a;border-color:var(--line);color:var(--muted)}[data-theme=dark] .task-del:hover{background:#333;color:var(--text)}[data-theme=dark] .balance-box{border-color:var(--line);color:var(--muted)}[data-theme=dark] .popover-title{color:var(--text)}[data-theme=dark] #recharge-btn{background:#e0e0e0;border-color:#e0e0e0;color:#111}[data-theme=dark] #recharge-btn:disabled,[data-theme=dark] #recharge-btn.is-disabled{background:#2a2a2a;border-color:#2a2a2a;color:var(--muted)}[data-theme=dark] #admin-entry-btn{background:#e0e0e0;border-color:#e0e0e0;color:#111}[data-theme=dark] #login-btn{background:#2a2a2a!important;border-color:#444!important;color:#e0e0e0!important}[data-theme=dark] #logout-btn{background:#e0e0e0;border-color:#e0e0e0;color:#111}[data-theme=dark] .card{background:var(--panel)}[data-theme=dark] .card-icon-btn{background:#232323eb;border-color:#ffffff1f}[data-theme=dark] .card-icon-btn svg{stroke:#e0e0e0}[data-theme=dark] .group-collage{background:var(--line)}[data-theme=dark] .group-collage-img{background:#2a2a2a}[data-theme=dark] .pending-card{background:#1a1a1a}[data-theme=dark] .project-hub{background:linear-gradient(180deg,#0a0a0a 0%,var(--bg) 40%,var(--bg) 100%)}[data-theme=dark] .hub-hero{background:#181818}[data-theme=dark] .hub-hero-title{color:#f0f0f0}[data-theme=dark] .hub-hero-desc{color:#999}[data-theme=dark] .hub-hero-hint{color:#555}[data-theme=dark] .hub-hero-btn-primary{background:#e0e0e0;color:#111}[data-theme=dark] .hub-hero-btn-primary:hover{background:#fff}[data-theme=dark] .hub-hero-btn-ghost{background:#2a2a2a;color:var(--text);border-color:var(--line)}[data-theme=dark] .hub-hero-btn-ghost:hover{background:#333;border-color:#444}[data-theme=dark] .hub-showcase-card{background:#2a2a2a;border-color:var(--line)}[data-theme=dark] .hub-showcase-card .hub-showcase-img{background:linear-gradient(140deg,#1a1a1a,#252525 48%,#1e1e1e)}[data-theme=dark] .hub-showcase-title,[data-theme=dark] .project-list-title{color:var(--text)}[data-theme=dark] .project-card{background:var(--panel);border-color:var(--line)}[data-theme=dark] .project-card:hover{box-shadow:0 12px 28px #00000080;border-color:#444}[data-theme=dark] .project-card-thumb{background:#2a2a2a}[data-theme=dark] .project-card-name{color:var(--text)}[data-theme=dark] .project-card-count,[data-theme=dark] .project-card-time{color:var(--muted)}[data-theme=dark] .project-card-del,[data-theme=dark] .project-card-rename,[data-theme=dark] .project-card-download{background:#1a1a1aeb;border-color:var(--line);color:var(--text)}[data-theme=dark] .project-card-new{background:var(--panel);border-color:var(--line);color:var(--muted)}[data-theme=dark] .project-card-new-plus{border-color:var(--line)}[data-theme=dark] .project-card-new:hover{border-color:#666;color:#ccc;background:#2a2a2a}[data-theme=dark] .project-card-new:hover .project-card-new-plus{border-color:#666}[data-theme=dark] .project-card-new-sub,[data-theme=dark] .project-image-count{color:var(--muted)}[data-theme=dark] .project-list-action-btn{background:var(--panel);color:var(--text);border-color:var(--line)}[data-theme=dark] .project-list-action-btn:hover{border-color:#666;color:#e0e0e0;background:#2a2a2a}[data-theme=dark] .project-card-name-input,[data-theme=dark] .workspace-project-title-input{background:#2a2a2a;border-color:#666;color:var(--text)}[data-theme=dark] .workspace-project-edit-btn{background:var(--panel);border-color:var(--line);color:var(--text)}[data-theme=dark] .workspace-project-edit-btn:hover{border-color:#666;color:#e0e0e0;background:#2a2a2a}[data-theme=dark] .oc-select-btn{background:var(--panel);border-color:var(--line);color:var(--text)}[data-theme=dark] .oc-select-btn:after{border-right-color:var(--muted);border-bottom-color:var(--muted)}[data-theme=dark] .oc-select-menu{background:#2a2a2a;border-color:var(--line);box-shadow:0 12px 24px #00000080}[data-theme=dark] .oc-select-option{color:var(--text)}[data-theme=dark] .oc-select-option:hover{background:#333}[data-theme=dark] .oc-select-option.active{background:#3a3a3a;color:#e0e0e0}[data-theme=dark] .suite-module-card{background:var(--panel);border-color:var(--line)}[data-theme=dark] .suite-module-card:hover{background:#2a2a2a;border-color:#444}[data-theme=dark] .suite-module-title{color:var(--text)}[data-theme=dark] .suite-module-desc{color:var(--muted)}[data-theme=dark] .suite-module-card:has(.suite-module-checkbox:checked){border-color:#3b82f6!important;background:#3b82f629!important;box-shadow:0 0 0 1px #3b82f6!important}[data-theme=dark] .suite-module-card:has(.suite-module-checkbox:checked) .suite-module-content{opacity:1!important}[data-theme=dark] .suite-module-card:has(.suite-module-checkbox:checked) .suite-module-title{color:#60a5fa!important}[data-theme=dark] .suite-module-card:has(.suite-module-checkbox:checked) .suite-module-desc{color:#93c5fd!important}[data-theme=dark] .prompt-dialog-panel{background:var(--panel);border-color:var(--line)}[data-theme=dark] .prompt-dialog-head{border-color:var(--line)}[data-theme=dark] .prompt-dialog-close{color:var(--muted)}[data-theme=dark] .prompt-dialog-text{color:var(--text)}[data-theme=dark] .prompt-dialog-copy{background:#e0e0e0;color:#111}[data-theme=dark] .notice-popup-panel{background:var(--panel);border-color:var(--line)}[data-theme=dark] .notice-popup-head{border-color:var(--line)}[data-theme=dark] .notice-popup-title{color:var(--text)}[data-theme=dark] .notice-popup-time{color:var(--muted)}[data-theme=dark] .notice-popup-body{color:#e8e8e8}[data-theme=dark] .notice-popup-body *{color:#e8e8e8!important}[data-theme=dark] .notice-popup-item+.notice-popup-item{border-color:var(--line)}[data-theme=dark] .notice-popup-actions{border-color:var(--line)}[data-theme=dark] .notice-popup-ok{background:#e0e0e0;color:#111}[data-theme=dark] .notice-popup-ok:hover{background:#fff}[data-theme=dark] .disclaimer-fab{background:var(--panel);border-color:var(--line)}[data-theme=dark] .disclaimer-text{color:var(--text);background:#2a2a2a;border-color:var(--line)}[data-theme=dark] .admin-panel-shell{background:var(--panel);border-color:var(--line)}[data-theme=dark] .admin-panel-head{border-color:var(--line)}[data-theme=dark] .admin-panel-title{color:var(--text)}[data-theme=dark] .admin-panel-sub,[data-theme=dark] .admin-panel-close{color:var(--muted)}[data-theme=dark] .admin-tabs{border-color:var(--line)}[data-theme=dark] .admin-tab{background:#2a2a2a;border-color:var(--line);color:var(--text)}[data-theme=dark] .admin-tab.active{background:#e0e0e0;border-color:#e0e0e0;color:#111}[data-theme=dark] .admin-panel-body,[data-theme=dark] .admin-section-head h3{color:var(--text)}[data-theme=dark] .admin-table-wrap{border-color:var(--line)}[data-theme=dark] .admin-table th{background:#2a2a2a;color:var(--muted)}[data-theme=dark] .admin-table th,[data-theme=dark] .admin-table td{border-color:var(--line);color:var(--text)}[data-theme=dark] .admin-inp,[data-theme=dark] .admin-ta{background:#2a2a2a;border-color:var(--line);color:var(--text)}[data-theme=dark] .admin-check{color:var(--text)}[data-theme=dark] .admin-hint{color:var(--muted)}[data-theme=dark] .admin-stat{background:#2a2a2a;border-color:var(--line)}[data-theme=dark] .admin-stat b{color:var(--text)}[data-theme=dark] .admin-stat span{color:var(--muted)}[data-theme=dark] .admin-hr{border-color:var(--line)}[data-theme=dark] .admin-link{color:#ccc}[data-theme=dark] .admin-link.danger{color:#f87171}[data-theme=dark] .mini-btn.danger{color:#f87171;border-color:#4a1a1a;background:#2a1010}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#444}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#555}[data-theme=dark] *{scrollbar-color:#444444 transparent}[data-theme=dark] .grid-hint{color:var(--muted)}.view-toggle-wrap{display:inline-flex;background:#e5e7eb80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px;border-radius:12px;border:1px solid var(--line);margin-right:8px;align-items:center}[data-theme=dark] .view-toggle-wrap{background:#28282880;border-color:var(--line)}.view-toggle-btn{display:flex;align-items:center;gap:6px;border:none;background:transparent;padding:6px 14px;font-size:12px;font-weight:700;color:var(--muted);border-radius:8px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);height:32px;line-height:1}.view-toggle-btn:hover{color:var(--text)}.view-toggle-btn.active{background:var(--panel);color:#2563eb;box-shadow:0 4px 12px #2563eb26,0 2px 4px #0000000d}[data-theme=dark] .view-toggle-btn.active{background:#333;color:#60a5fa;box-shadow:0 4px 12px #60a5fa33}.view-toggle-icon{width:15px;height:15px;stroke:currentColor;transition:transform .25s ease}.view-toggle-btn.active .view-toggle-icon{transform:scale(1.1)}.left-panel.canvas-history-active>*:not(.mode-tabs-segment):not(.canvas-history-panel){display:none!important}.left-panel.canvas-history-active{padding-bottom:14px;overflow:hidden!important;max-height:100%!important}.left-panel.canvas-history-active .mode-tabs-segment{background:transparent;border:none;padding:0;margin:0 0 4px;gap:6px}.left-panel.canvas-history-active .mode-tabs-segment .mode-tab{height:28px;border:1.5px solid var(--line);border-radius:8px;background:transparent;color:var(--muted);font-size:11px;font-weight:600;transition:all .18s;letter-spacing:.02em}.left-panel.canvas-history-active .mode-tabs-segment .mode-tab:hover{border-color:#3b82f6;color:#3b82f6;background:#3b82f60d}.left-panel.canvas-history-active .mode-tabs-segment .mode-tab.active{border-color:#3b82f6;background:#3b82f6;color:#fff;box-shadow:none}[data-theme=dark] .left-panel.canvas-history-active .mode-tabs-segment .mode-tab.active{background:#2563eb;border-color:#2563eb}.canvas-history-panel{display:flex;flex-direction:column;flex:1;min-height:0;gap:12px}.canvas-history-title{font-size:13px;font-weight:800;color:var(--text);padding:4px 0 2px;border-bottom:2px solid var(--line);display:flex;justify-content:space-between;align-items:center}.canvas-history-list{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:min-content;gap:10px;overflow-y:auto;flex:1;padding-right:2px}.canvas-history-item{position:relative;aspect-ratio:1/1;min-width:0;min-height:0;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#f8fafc;cursor:grab;transition:all .2s ease}[data-theme=dark] .canvas-history-item{background:#1a1a1a}.canvas-history-item:hover{transform:translateY(-2px);box-shadow:0 6px 14px #0000001f;border-color:#2563eb}.canvas-history-item img{width:100%;height:100%;object-fit:cover;pointer-events:none}.canvas-history-drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;pointer-events:none}.canvas-history-item:hover .canvas-history-drag-overlay{opacity:1}.canvas-history-drag-overlay svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.5}.canvas-history-tabs{display:flex;gap:6px;padding:0 0 2px}.ch-tab{flex:1;height:28px;border:1.5px solid var(--line);border-radius:8px;background:transparent;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .18s;letter-spacing:.02em}.ch-tab:hover{border-color:#3b82f6;color:#3b82f6;background:#3b82f60d}.ch-tab.active{border-color:#3b82f6;background:#3b82f6;color:#fff}[data-theme=dark] .ch-tab.active{background:#2563eb;border-color:#2563eb}.omni-canvas-container{position:relative;width:100%;height:100%;overflow:hidden;background-color:#fafbfc;background-image:linear-gradient(to right,rgba(17,24,39,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(17,24,39,.04) 1px,transparent 1px);background-size:40px 40px;-webkit-user-select:none;user-select:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}[data-theme=dark] .omni-canvas-container{background-color:#0f0f10;background-image:linear-gradient(to right,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.035) 1px,transparent 1px)}.omni-canvas-container.no-grid{background-image:none}.omni-canvas{position:absolute;width:100%;height:100%;transform-origin:0 0;cursor:grab;will-change:transform}.omni-canvas:active{cursor:grabbing}.canvas-empty-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:0}.canvas-empty-hint-inner{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px;border-radius:24px;border:1.5px dashed rgba(0,0,0,.1);background:#fff6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);max-width:360px}[data-theme=dark] .canvas-empty-hint-inner{border-color:#ffffff1a;background:#00000026}.omni-svg-layer{position:absolute;width:20000px;height:20000px;left:-10000px;top:-10000px;pointer-events:none;z-index:1}.connection-curve{fill:none;stroke:#9ca3af4d;stroke-width:2;transition:stroke .2s,stroke-width .2s}.connection-curve.active{stroke:#9ca3af33;stroke-width:1.5;filter:none}.connection-curve.active.selected{stroke:#3b82f64d}.connection-curve.active-glow{stroke:#9ca3af73;stroke-width:1.8;stroke-dasharray:8,6}.connection-curve.active-glow.selected{stroke:#3b82f6;stroke-width:2.2}[data-theme=dark] .connection-curve.active{stroke:#9ca3af26}[data-theme=dark] .connection-curve.active.selected{stroke:#60a5fa4d}[data-theme=dark] .connection-curve.active-glow{stroke:#9ca3af59}[data-theme=dark] .connection-curve.active-glow.selected{stroke:#60a5fa}.connection-delete-btn{position:absolute;width:20px;height:20px;background:#ffffffe6;border:1px solid rgba(239,68,68,.4);border-radius:50%;color:#ef4444;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;cursor:pointer;transform:translate(-50%,-50%) scale(.85);transition:all .2s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 2px 6px #00000014;pointer-events:auto!important;z-index:100;-webkit-user-select:none;user-select:none;opacity:0}.connection-delete-btn.visible{opacity:1}.connection-delete-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff;transform:translate(-50%,-50%) scale(1.1);box-shadow:0 4px 10px #ef444459}[data-theme=dark] .connection-delete-btn{background:#18181be6;border-color:#ef444480;box-shadow:0 2px 6px #0003}[data-theme=dark] .connection-delete-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff}.omni-nodes-layer{position:absolute;left:0;top:0;z-index:2;pointer-events:none}.omni-node{position:absolute;width:260px;border-radius:16px;background:#fffffff5;border:1px solid rgba(229,231,235,.9);box-shadow:0 10px 30px #00000014,0 1px 3px #00000005;display:flex;flex-direction:column;pointer-events:auto;cursor:grab;-webkit-user-select:none;user-select:none;z-index:10;transition:border-color .2s,box-shadow .2s,ring .2s;-webkit-font-smoothing:subpixel-antialiased;-moz-osx-font-smoothing:auto;will-change:transform,left,top}[data-theme=dark] .omni-node{background:#18181bf5;border-color:#3f3f46cc;box-shadow:0 10px 35px #00000059}.omni-node:active{cursor:grabbing}.omni-node.selected{border-color:#2563ebcc;box-shadow:0 12px 40px #2563eb2e,0 0 0 2px #2563eb26}[data-theme=dark] .omni-node.selected{border-color:#60a5facc;box-shadow:0 12px 40px #60a5fa40,0 0 0 2px #60a5fa2e}.omni-node-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(229,231,235,.5);font-weight:700;font-size:12px}[data-theme=dark] .omni-node-header{border-bottom-color:#3f3f464d}.omni-node-header-title{display:flex;align-items:center;gap:6px;color:var(--text)}.omni-node-header-icon{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.5}.omni-node-header-del{border:none;background:transparent;color:var(--muted);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;justify-content:center}.omni-node-header-del:hover{background:#ef44441a;color:#ef4444}.omni-node-body{padding:12px;display:flex;flex-direction:column;gap:10px}.omni-node-body textarea{width:100%;min-height:70px;resize:vertical;background:#f8f9fa;border:1px solid #e4e4e7;font-size:11.5px;border-radius:10px;padding:8px 12px;outline:none;color:#3f3f46;transition:background .2s,border-color .2s,box-shadow .2s;font-family:inherit}.omni-node-body textarea:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}[data-theme=dark] .omni-node-body textarea{background:#18181b;color:#e4e4e7;border-color:#3f3f46}[data-theme=dark] .omni-node-body textarea:focus{background:#09090b}.omni-node-body select,.omni-node-body input[type=text]{height:34px;font-size:11.5px;padding:0 24px 0 10px;border-radius:10px;background-color:#fff;color:#3f3f46;border:1px solid #e4e4e7;outline:none;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:12px}.omni-node-body select:hover,.omni-node-body input[type=text]:hover{border-color:#cbd5e1}.omni-node-body select:focus,.omni-node-body input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}[data-theme=dark] .omni-node-body select,[data-theme=dark] .omni-node-body input[type=text]{background-color:#18181b;color:#e4e4e7;border-color:#3f3f46;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")}.omni-node-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.omni-node-btn{width:100%;height:34px;background:#eceffd;color:#3b82f6;border:none;font-size:12px;font-weight:700;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:none}.omni-node-btn:hover{background:#dbf1ff;color:#1d4ed8;transform:translateY(-1px)}.omni-node-btn:active{transform:translateY(0)}[data-theme=dark] .omni-node-btn{background:#3b82f626;color:#60a5fa}[data-theme=dark] .omni-node-btn:hover{background:#3b82f640;color:#93c5fd}.omni-node.node-image{padding:0;border:1px solid rgba(229,231,235,.9);background:transparent;box-shadow:0 10px 30px #0000000a,0 1px 3px #00000005}.omni-node.node-image.selected{border-color:#3b82f6;box-shadow:0 12px 40px #2563eb26,0 0 0 1px #2563eb1a}[data-theme=dark] .omni-node.node-image.selected{border-color:#60a5fa;box-shadow:0 12px 40px #60a5fa38,0 0 0 1px #60a5fa26}.omni-node-image-container{position:relative;width:100%;border-radius:16px;overflow:hidden;background:#f4f4f5;border:none}[data-theme=dark] .omni-node-image-container{background:#18181b}.omni-node-image-container img{width:100%;height:100%;object-fit:cover;cursor:zoom-in}.omni-node-image-prompt{font-size:10px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;margin-top:2px}.omni-node-image-del-btn{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;background:#ffffffd9;border:1px solid rgba(239,68,68,.2);color:#ef4444;font-size:10px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s cubic-bezier(.175,.885,.32,1.275);z-index:100;pointer-events:auto;box-shadow:0 2px 6px #00000014;-webkit-user-select:none;user-select:none}.omni-node-image-dl-btn{position:absolute;top:10px;right:38px;width:22px;height:22px;border-radius:50%;background:#ffffffd9;border:1px solid rgba(37,99,235,.2);color:#2563eb;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s cubic-bezier(.175,.885,.32,1.275);z-index:100;pointer-events:auto;box-shadow:0 2px 6px #00000014;-webkit-user-select:none;user-select:none;padding:0}.omni-node-image-dl-btn svg{width:12px;height:12px;stroke:currentColor}.omni-node.node-image:hover .omni-node-image-dl-btn{opacity:1}.omni-node-image-dl-btn:hover{background:#2563eb;border-color:#2563eb;color:#fff;transform:scale(1.15);box-shadow:0 4px 10px #2563eb59}[data-theme=dark] .omni-node-image-dl-btn{background:#18181bd9;border-color:#60a5fa66;color:#60a5fa}.omni-node.node-image:hover .omni-node-image-del-btn{opacity:1}.omni-node-image-del-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff;transform:scale(1.15);box-shadow:0 4px 10px #ef444459}[data-theme=dark] .omni-node-image-del-btn{background:#18181bd9;border-color:#ef444466}.omni-node-resize-handle{position:absolute;bottom:4px;right:4px;width:14px;height:14px;cursor:nwse-resize;opacity:0;transition:opacity .15s;z-index:101;pointer-events:auto;display:flex;align-items:center;justify-content:center}.omni-node.node-image:hover .omni-node-resize-handle{opacity:1}.omni-node-resize-handle svg{width:10px;height:10px;stroke:#6b7280;stroke-width:2}[data-theme=dark] .omni-node-resize-handle svg{stroke:#9ca3af}.omni-node.node-generating{animation:nodeGlowPulse 1.8s ease-in-out infinite}@keyframes nodeGlowPulse{0%,to{box-shadow:0 10px 30px #00000014,0 0 0 1px #2563eb1a}50%{box-shadow:0 12px 35px #2563eb40,0 0 0 3px #2563eb40}}[data-theme=dark] .omni-node.node-generating{animation:nodeGlowPulseDark 1.8s ease-in-out infinite}@keyframes nodeGlowPulseDark{0%,to{box-shadow:0 10px 35px #00000059,0 0 0 1px #60a5fa26}50%{box-shadow:0 15px 45px #60a5fa66,0 0 0 4px #60a5fa4d}}.node-progress-bar-wrap{width:100%;height:4px;background:#e5e7eb80;border-radius:2px;overflow:hidden}[data-theme=dark] .node-progress-bar-wrap{background:#3f3f4666}.node-progress-bar{height:100%;background:#2563eb;transition:width .3s ease;border-radius:2px}[data-theme=dark] .node-progress-bar{background:#60a5fa}.node-img-pending-placeholder{background:var(--panel, #f4f4f5)}[data-theme=dark] .node-img-pending-placeholder{background:#18181b}.node-img-pending-spinner{width:28px;height:28px;border:3px solid rgba(37,99,235,.15);border-top-color:#2563eb;border-radius:50%;animation:nodeImgSpinner .8s linear infinite}[data-theme=dark] .node-img-pending-spinner{border-color:#60a5fa26;border-top-color:#60a5fa}@keyframes nodeImgSpinner{to{transform:rotate(360deg)}}.omni-node-port{position:absolute;width:12px;height:12px;background:#fff;border:3px solid #9ca3af;border-radius:50%;top:50%;transform:translateY(-50%);cursor:crosshair;z-index:1000!important;pointer-events:auto!important;transition:background .2s,border-color .2s,transform .2s;box-shadow:0 2px 5px #0000001a}.omni-node-port:after{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;background:transparent;z-index:1001}[data-theme=dark] .omni-node-port{background:#1e1e20;border-color:#52525b}.omni-node-port:hover{transform:translateY(-50%) scale(1.3);border-color:#3b82f6;box-shadow:0 0 8px #3b82f680}[data-theme=dark] .omni-node-port:hover{border-color:#60a5fa;box-shadow:0 0 8px #60a5fa99}.omni-node-port.port-left{left:-7px}.omni-node-port.port-right{right:-7px}.port-label{position:absolute;font-size:8px;font-weight:700;background:#111827cc;color:#fff;padding:1px 4px;border-radius:4px;top:50%;transform:translateY(-50%);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s;z-index:50}.omni-node-port:hover .port-label{opacity:1}.port-label-left{right:calc(100% + 6px)}.port-label-right{left:calc(100% + 6px)}.omni-node-multi-ports{position:absolute;left:-7px;top:0;bottom:0;width:14px;display:flex;flex-direction:column;justify-content:space-evenly;pointer-events:none}.omni-node-multi-ports .omni-node-port{position:relative;top:auto;transform:none;pointer-events:auto}.omni-node-multi-ports .omni-node-port:hover{transform:scale(1.3)}.omni-minimap-panel{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:100}.omni-minimap{width:220px;height:150px;background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(229,231,235,.6);border-radius:12px;box-shadow:0 10px 25px #00000014;overflow:hidden;position:relative}[data-theme=dark] .omni-minimap{background:#1e1e20a6;border-color:#3f3f4666;box-shadow:0 10px 25px #0000004d}#omniMinimapCanvas{width:100%;height:100%;display:block}.omni-minimap-viewport{position:absolute;border:1.5px solid #2563eb;background:#2563eb0d;border-radius:4px;cursor:move;z-index:110}[data-theme=dark] .omni-minimap-viewport{border-color:#60a5fa;background:#60a5fa0d}.canvas-controls{display:flex;flex-direction:row;justify-content:center;gap:6px;padding:8px;background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(229,231,235,.6);border-radius:12px;box-shadow:0 10px 25px #00000014;width:220px;box-sizing:border-box}[data-theme=dark] .canvas-controls{background:#1e1e20a6;border-color:#3f3f4666;box-shadow:0 10px 25px #0000004d}.canvas-control-btn{width:36px;height:36px;flex-shrink:0;border-radius:50%;background:#ffffffd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(229,231,235,.6);color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #0000000d;transition:all .2s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .canvas-control-btn{background:#28282ad9;border-color:#3f3f4666;color:#9ca3af}.canvas-control-btn:hover{transform:translateY(-2px) scale(1.05);color:#2563eb;box-shadow:0 8px 20px #2563eb26}[data-theme=dark] .canvas-control-btn:hover{color:#60a5fa;box-shadow:0 8px 20px #60a5fa40}.canvas-control-btn:active{transform:scale(.95)}.canvas-control-btn.active{color:#6b7280;opacity:.5}.control-svg{width:15px;height:15px}.dragging-ghost-preview{width:80px;height:80px;border-radius:8px;overflow:hidden;box-shadow:0 10px 25px #00000040;position:absolute;top:-9999px;left:-9999px;z-index:-100}.dragging-ghost-preview img{width:100%;height:100%;object-fit:cover}.canvas-context-menu{position:fixed;z-index:10000;background:#ffffffd9;backdrop-filter:blur(20px) saturate(190%);-webkit-backdrop-filter:blur(20px) saturate(190%);border:1px solid rgba(255,255,255,.5);border-radius:14px;box-shadow:0 10px 30px #0000000f,0 1px 3px #00000005;padding:6px;min-width:170px;display:flex;flex-direction:column;gap:2px;transform-origin:top left;animation:menuFadeIn .16s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .canvas-context-menu{background:#1a1a1ce0;border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 30px #00000040}@keyframes menuFadeIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.canvas-menu-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:600;color:var(--text);border-radius:8px;cursor:pointer;background:transparent;border:none;text-align:left;transition:background .15s,color .15s}.canvas-menu-item:hover{background:#2563eb14;color:#2563eb}[data-theme=dark] .canvas-menu-item:hover{background:#60a5fa1f;color:#60a5fa}.canvas-menu-item svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.2}.canvas-sidebar-toggleBtn{position:absolute;left:16px;top:16px;width:36px;height:36px;border-radius:10px;background:var(--panel);border:1px solid var(--line);color:var(--text);box-shadow:0 4px 12px #00000014;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:1005!important;transition:all .2s cubic-bezier(.4,0,.2,1)}.canvas-sidebar-toggleBtn:hover{background:var(--bg);transform:scale(1.05)}.canvas-sidebar-toggleBtn svg{width:16px;height:16px;stroke:currentColor;transition:transform .3s ease}.omni-canvas-container:not(.hidden) .canvas-sidebar-toggleBtn{display:flex!important}[data-theme=dark] .canvas-sidebar-toggleBtn{background:#232323;border-color:#333}.omni-node{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px #00000014;transition:box-shadow .2s,border-color .2s,transform .2s;-webkit-font-smoothing:subpixel-antialiased;-moz-osx-font-smoothing:auto}.omni-node.selected{outline:2.5px solid #3b82f6;outline-offset:1px;box-shadow:0 14px 40px #3b82f629}[data-theme=dark] .omni-node.selected{outline-color:#60a5fa;box-shadow:0 14px 40px #60a5fa42}.omni-node.node-stitcher{border-top:4px solid #10b981}.omni-node.node-group{background:#ffffff8c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:2px dashed rgba(156,163,175,.4)}[data-theme=dark] .omni-node.node-group{background:#1e1e208c;border-color:#73737366}.canvas-marquee{position:absolute;border:1.5px dashed #2563eb;background:#2563eb14;pointer-events:none;z-index:9999}[data-theme=dark] .canvas-marquee{border-color:#60a5fa;background:#60a5fa1f}.crop-overlay-container{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:50;pointer-events:auto}.crop-box-active{position:absolute;border:2px solid #3b82f6;box-shadow:0 0 0 9999px #00000080;cursor:move}.crop-handle{position:absolute;width:10px;height:10px;background:#fff;border:2px solid #3b82f6;z-index:60}.crop-handle-nw{top:-6px;left:-6px;cursor:nwse-resize}.crop-handle-ne{top:-6px;right:-6px;cursor:nesw-resize}.crop-handle-sw{bottom:-6px;left:-6px;cursor:nesw-resize}.crop-handle-se{bottom:-6px;right:-6px;cursor:nwse-resize}.outpaint-handle-arrow{position:absolute;width:24px;height:24px;background:#8b5cf6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:55;box-shadow:0 2px 6px #0003;transition:transform .2s}.outpaint-handle-arrow:hover{transform:scale(1.2);background:#a78bfa}.outpaint-top-arrow{top:-12px;left:50%;transform:translate(-50%)}.outpaint-bottom-arrow{bottom:-12px;left:50%;transform:translate(-50%)}.outpaint-left-arrow{left:-12px;top:50%;transform:translateY(-50%)}.outpaint-right-arrow{right:-12px;top:50%;transform:translateY(-50%)}.outpaint-config-drawer{background:var(--panel);border-radius:12px;border:1px solid var(--line);padding:10px;display:flex;flex-direction:column;gap:8px;margin-top:8px}.ms-box-source{position:absolute;border:2px solid #f59e0b;background:#f59e0b26;pointer-events:none;z-index:10;box-sizing:border-box}.ms-box-target{position:absolute;border:2px dashed #3b82f6;background:#3b82f626;pointer-events:none;z-index:10;box-sizing:border-box}.ms-overlay{position:absolute;left:0;top:0;width:100%;height:100%;cursor:crosshair;z-index:5;background:transparent}.drawer-btn.active{color:#fff!important}.tool-brush-btn.active{background:#ef4444!important;border-color:#ef4444!important}.tool-outpaint-btn.active{background:#8b5cf6!important;border-color:#8b5cf6!important}.tool-ma-btn.active{background:#06b6d4!important;border-color:#06b6d4!important}.tool-ocr-btn.active{background:#f97316!important;border-color:#f97316!important}.tool-movescale-btn.active{background:#f59e0b!important;border-color:#f59e0b!important}.ma-sphere-container{position:relative;width:120px;height:120px;background:#0000000a;border:1px solid var(--line);border-radius:50%;perspective:600px;cursor:move;margin:0 auto;overflow:hidden;box-shadow:inset 0 2px 8px #0000000f}[data-theme=dark] .ma-sphere-container{background:#ffffff08}.ma-sphere-ball{width:100%;height:100%;position:absolute;transform-style:preserve-3d;transition:transform .1s linear}.ma-sphere-circle{position:absolute;width:100%;height:100%;border:1px dashed rgba(107,114,128,.35);border-radius:50%}.ma-sphere-h{transform:rotateX(90deg)}.ma-sphere-v{transform:rotateY(90deg)}.ma-sphere-preview-img{position:absolute;top:50%;left:50%;width:50px;height:50px;object-fit:cover;border-radius:8px;box-shadow:0 4px 10px #00000026;transform:translate(-50%,-50%) translateZ(0)}.ma-presets-row{display:flex;gap:4px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.ma-presets-row::-webkit-scrollbar{display:none}.ma-preset-pill{padding:4px 8px;border-radius:6px;font-size:10px;font-weight:700;border:1px solid var(--line);background:var(--panel);color:var(--text);cursor:pointer;white-space:nowrap;transition:all .15s}.ma-preset-pill.active{background:#06b6d4;border-color:#06b6d4;color:#fff}.ocr-replacement-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto;border:1px solid var(--line);border-radius:10px;padding:6px;background:#00000005}[data-theme=dark] .ocr-replacement-list{background:#ffffff03}.ocr-replacement-item{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;padding:4px;border-bottom:1px solid var(--line)}.ocr-original-text{font-size:11px;font-weight:600;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ocr-item-arrow{font-size:10px;color:var(--muted)}.ocr-replacement-input{height:26px;padding:2px 6px;border:1px solid var(--line);border-radius:6px;font-size:11px;background:var(--panel);color:var(--text)}.omni-node-actions-trigger{position:absolute;bottom:6px;left:6px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;opacity:0;transition:opacity .2s}.omni-node:hover .omni-node-actions-trigger{opacity:1}.omni-node-actions-trigger svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5}.omni-node-actions-drawer{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);width:260px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:8px;z-index:100;display:flex;flex-direction:column;gap:6px;font-size:11px}.omni-node-info-block{padding:6px 8px;background:var(--bg);border-radius:8px;border:1px solid var(--line);display:flex;flex-direction:column;gap:4px}.omni-node-info-size{font-size:10px;color:var(--muted);font-weight:600;letter-spacing:.02em}.omni-node-info-prompt{font-size:10px;color:var(--text);line-height:1.5;max-height:60px;overflow-y:auto;word-break:break-all}.omni-node-info-prompt:empty:before{content:"暂无提示词";color:var(--muted)}.drawer-row{display:flex;gap:4px;justify-content:space-between}.drawer-btn{flex:1;height:28px;padding:0 4px;border:1px solid var(--line);border-radius:6px;background:var(--panel);color:var(--text);font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;font-size:10px}.drawer-btn:hover{background:#00000008}[data-theme=dark] .drawer-btn:hover{background:#ffffff08}.snapshot-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1500;display:flex;align-items:center;justify-content:center;padding:16px}.snapshot-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a8c}.snapshot-shell{position:relative;width:min(520px,94vw);max-height:80vh;background:var(--panel);border-radius:16px;border:1px solid var(--line);box-shadow:0 20px 50px #00000026;display:flex;flex-direction:column;overflow:hidden}.snapshot-head{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}.snapshot-title{font-size:15px;font-weight:700}.snapshot-close{border:none;background:transparent;font-size:16px;cursor:pointer;color:var(--muted)}.snapshot-body{padding:14px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:8px}.snapshot-card{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--panel)}.snapshot-meta{display:flex;flex-direction:column;gap:2px}.snapshot-name{font-size:12px;font-weight:700}.snapshot-time{font-size:10px;color:var(--muted)}.snapshot-actions{display:flex;gap:6px}.export-popover-options{position:absolute;top:42px;right:0;width:240px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 10px 25px #0000001f;padding:6px;z-index:200;display:flex;flex-direction:column;gap:2px}.export-option-btn{display:flex;flex-direction:column;align-items:flex-start;padding:8px 10px;border:none;background:transparent;border-radius:8px;cursor:pointer;text-align:left;transition:background .15s;width:100%}.export-option-btn:hover{background:#00000008}[data-theme=dark] .export-option-btn:hover{background:#ffffff08}.export-option-title{font-size:11px;font-weight:700;color:var(--text)}.export-option-desc{font-size:9px;color:var(--muted);margin-top:2px;line-height:1.3}.canvas-select-wrapper{position:relative;flex:1;display:flex;flex-direction:column}.canvas-select-label{position:absolute;top:-6px;left:10px;background:var(--panel);padding:0 4px;font-size:9px;color:var(--muted);line-height:1;z-index:2;pointer-events:none;border-radius:4px;border:none}.omni-node-row .oc-select-btn{height:36px!important;border-radius:10px!important;font-size:11px!important;padding:0 28px 0 10px!important;display:flex!important;align-items:center!important;border:1.5px solid var(--line)!important;background:var(--panel)!important;color:var(--text)!important}.omni-node-row .oc-select-btn:after{right:10px!important}[data-theme=dark] .canvas-select-label{background:var(--panel, #18181b)!important}[data-theme=dark] .omni-node-row .oc-select-btn{border-color:#3f3f46cc!important}.omni-alignment-toolbar{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:16px;background:#ffffffdb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(228,228,231,.6);box-shadow:0 10px 40px -10px #0000001f,0 1px 3px #00000005;transition:all .25s cubic-bezier(.4,0,.2,1);animation:slideDownIn .3s cubic-bezier(.34,1.56,.64,1);-webkit-user-select:none;user-select:none}[data-theme=dark] .omni-alignment-toolbar{background:#18181bdb;border-color:#3f3f4699;box-shadow:0 10px 45px -10px #00000073}.omni-alignment-toolbar.fade-out{opacity:0;transform:translate(-50%,-15px) scale(.95);pointer-events:none}@keyframes slideDownIn{0%{opacity:0;transform:translate(-50%,-20px) scale(.95)}to{opacity:1;transform:translate(-50%) scale(1)}}.alignment-group-title{font-size:11px;font-weight:700;color:#71717a;margin-right:4px}[data-theme=dark] .alignment-group-title{color:#a1a1aa}.alignment-divider{width:1px;height:18px;background:#e4e4e7cc;margin:0 4px}[data-theme=dark] .alignment-divider{background:#3f3f46cc}.alignment-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:transparent;border:none;color:#3f3f46;cursor:pointer;transition:all .16s ease;padding:0}[data-theme=dark] .alignment-btn{color:#e4e4e7}.alignment-btn:hover{background:#0000000d;color:#2563eb;transform:translateY(-1px)}[data-theme=dark] .alignment-btn:hover{background:#ffffff14;color:#60a5fa}.alignment-btn:active{transform:translateY(0)}.alignment-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.canvas-help-wrap{position:absolute;left:20px;bottom:20px;z-index:100;pointer-events:auto;font-family:inherit}.canvas-help-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:#ffffffb3;backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);color:#1e293b;cursor:pointer;box-shadow:0 4px 16px #00000014;transition:all .3s cubic-bezier(.4,0,.2,1)}.canvas-help-btn:hover{transform:translateY(-2px) scale(1.05);background:#fffffff2;border-color:#3b82f666;box-shadow:0 6px 20px #3b82f626;color:#2563eb}.canvas-help-icon{width:18px;height:18px;opacity:.85}[data-theme=dark] .canvas-help-btn{background:#0f172abf;border:1px solid rgba(255,255,255,.08);color:#f1f5f9;box-shadow:0 4px 16px #00000040}[data-theme=dark] .canvas-help-btn:hover{background:#1e293bf2;border-color:#3b82f680;box-shadow:0 6px 20px #3b82f64d;color:#60a5fa}.canvas-help-panel{position:absolute;bottom:50px;left:0;width:360px;max-height:480px;border-radius:16px;border:1px solid rgba(0,0,0,.08);background:#ffffffd9;backdrop-filter:blur(20px) saturate(190%);-webkit-backdrop-filter:blur(20px) saturate(190%);box-shadow:0 12px 40px #0000001f;display:flex!important;flex-direction:column;overflow:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1),visibility .3s;transform-origin:bottom left;transform:translateY(0) scale(1);opacity:1;visibility:visible;pointer-events:auto}.canvas-help-panel.hidden{display:flex!important;transform:translateY(12px) scale(.95);opacity:0;visibility:hidden;pointer-events:none}[data-theme=dark] .canvas-help-panel{background:#0f172ad9;border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 40px #0006}.canvas-help-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(0,0,0,.06)}[data-theme=dark] .canvas-help-header{border-bottom:1px solid rgba(255,255,255,.06)}.canvas-help-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:#0f172a}.canvas-help-title svg{color:#3b82f6}[data-theme=dark] .canvas-help-title{color:#f8fafc}[data-theme=dark] .canvas-help-title svg{color:#60a5fa}.canvas-help-close-btn{background:none;border:none;font-size:14px;color:#64748b;cursor:pointer;padding:4px;line-height:1;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s}.canvas-help-close-btn:hover{background:#0000000d;color:#0f172a}[data-theme=dark] .canvas-help-close-btn:hover{background:#ffffff14;color:#f8fafc}.canvas-help-content{padding:16px 18px;overflow-y:auto;flex:1}.shortcut-group-title{font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}[data-theme=dark] .shortcut-group-title{color:#94a3b8}.shortcut-grid{display:flex;flex-direction:column;gap:8px}.shortcut-item{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:#334155;padding:2px 0}[data-theme=dark] .shortcut-item{color:#cbd5e1}.shortcut-keys{font-weight:600;color:#0f172a}[data-theme=dark] .shortcut-keys{color:#f1f5f9}.shortcut-keys kbd{display:inline-block;padding:2px 6px;font-size:11px;font-family:inherit;line-height:1.2;color:#1e293b;background-color:#0000000d;border:1px solid rgba(0,0,0,.15);border-radius:4px;box-shadow:0 1px #0000001a;margin:0 1px}[data-theme=dark] .shortcut-keys kbd{color:#e2e8f0;background-color:#ffffff14;border:1px solid rgba(255,255,255,.15);box-shadow:0 1px #ffffff0d}.shortcut-desc{color:#64748b;font-size:12px;text-align:right;max-width:190px}[data-theme=dark] .shortcut-desc{color:#94a3b8}
