:root{--bg: #f3f5f9;--surface: rgba(255, 255, 255, .75);--surface-soft: rgba(248, 250, 252, .6);--border: rgba(226, 232, 240, .6);--border-strong: rgba(203, 213, 225, .8);--text: #1e293b;--muted: #64748b;--muted-2: #94a3b8;--primary: #0f172a;--primary-2: #3b82f6;--success: #10b981;--error: #ef4444;--warning: #f59e0b;--radius: 20px;--shadow-sm: 0 2px 8px rgba(15, 23, 42, .04);--shadow-md: 0 8px 24px rgba(15, 23, 42, .06);--shadow-lg: 0 20px 48px rgba(15, 23, 42, .08);--glass-blur: blur(24px);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b899}body{margin:0;background:radial-gradient(circle at 15% 10%,#e0ebff 0%,transparent 40%),radial-gradient(circle at 85% 90%,#dcfce7 0%,transparent 40%),var(--bg);background-attachment:fixed;color:var(--text);-webkit-font-smoothing:antialiased}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}code{font-size:.85em}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-panel{width:min(420px,100%);background:#ffffffeb;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-lg);padding:22px}.auth-brand{margin-bottom:18px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;border:1px solid var(--border);border-radius:12px;padding:4px;background:var(--surface-soft);margin-bottom:16px}.auth-tabs button{border:0;background:transparent;color:var(--muted);border-radius:9px;padding:10px;font-weight:700}.auth-tabs button.active{background:#111827;color:#fff}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-submit{width:100%}.auth-error{border:1px solid #fecaca;background:#fff7f7;color:var(--error);border-radius:12px;padding:10px 12px;font-size:13px}.auth-loading{color:var(--muted);text-align:center;margin:14px 0 0}.app-shell{min-height:100vh;padding:18px}.topbar{height:72px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 4px 18px;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:linear-gradient(to bottom,rgba(243,245,249,.9),transparent);margin-bottom:-10px;z-index:10;position:relative}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:42px;height:42px;border-radius:13px;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;display:grid;place-items:center;font-weight:800;letter-spacing:-.05em;box-shadow:0 4px 12px #3b82f64d}.brand h1{margin:0;font-size:20px;letter-spacing:-.03em}.brand p{margin:2px 0 0;color:var(--muted);font-size:13px}.top-actions{display:flex;align-items:center;gap:10px}.config-pill{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border:1px solid var(--border);border-radius:999px;background:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.config-pill span{white-space:nowrap;font-size:13px;font-weight:700;color:var(--primary-2)}.workspace{display:grid;grid-template-columns:340px minmax(0,1fr) 360px;gap:18px;align-items:start}.workspace.history-collapsed{grid-template-columns:340px minmax(0,1fr) 76px}.sidebar,.history-panel,.canvas-area{background:var(--surface);border:1px solid rgba(255,255,255,.8);border-radius:var(--radius);box-shadow:var(--shadow-md);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);transition:transform .2s ease,box-shadow .2s ease}.sidebar:hover,.canvas-area:hover{box-shadow:var(--shadow-lg)}.sidebar{padding:18px;position:sticky;top:18px}.panel{margin-bottom:18px}.panel:last-child{margin-bottom:0}.label,.field>span{display:block;font-size:13px;color:var(--muted);margin-bottom:8px;font-weight:600}.label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.label-row .label{margin:0}.label-row span{color:var(--muted);font-size:12px}.mode-tabs,.request-mode-tabs{display:grid;gap:6px;padding:4px;border-radius:12px;background:#0f172a0a;box-shadow:inset 0 1px 3px #0000000d;border:1px solid transparent}.mode-tabs{grid-template-columns:1fr 1fr}.request-mode-tabs{grid-template-columns:repeat(3,1fr)}.mode-tabs button,.request-mode-tabs button{border:0;background:transparent;color:var(--muted);border-radius:9px;padding:10px;font-weight:700}.mode-tabs button.active,.request-mode-tabs button.active{background:#fff;color:var(--primary);box-shadow:0 2px 8px #00000014;border:1px solid rgba(0,0,0,.04)}.prompt-input,.text-input,.field input,.field textarea,.settings-modal input{width:100%;border-radius:12px;padding:11px 12px;outline:none;background:#ffffffe6;border:1px solid rgba(226,232,240,.8);box-shadow:inset 0 2px 4px #00000005;color:var(--text);transition:all .25s cubic-bezier(.4,0,.2,1)}.prompt-input{min-height:136px;resize:vertical;line-height:1.5}.prompt-input:focus,.text-input:focus,.field input:focus,.settings-modal input:focus{border-color:var(--primary-2);background:#fff;box-shadow:0 0 0 4px #3b82f626,inset 0 1px 2px #00000003;transform:translateY(-1px)}.split-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.field.compact{margin:0}.ratio-list{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.ratio-btn{border:1px solid var(--border);background:#fff;border-radius:12px;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--muted);font-size:12px}.ratio-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f640}.ratio-icon{border:1.7px solid currentColor;border-radius:3px;display:block}.resolution-list{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.resolution-btn{border:1px solid var(--border);background:#fff;border-radius:12px;padding:10px 6px;color:var(--muted);font-size:13px;font-weight:700}.resolution-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f640}.hint-text{display:block;margin-top:8px;color:var(--muted-2);font-size:12px;line-height:1.5}.generate-btn,.primary-btn,.secondary-btn,.ghost-btn,.icon-btn{border:0;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.generate-btn{width:100%;padding:15px;color:#fff;background:linear-gradient(135deg,#3b82f6,#6366f1);box-shadow:0 8px 20px #3b82f640,inset 0 1px 1px #fff3;transition:all .2s ease;transform:translateY(0)}.generate-btn:hover{box-shadow:0 12px 24px #3b82f666,inset 0 1px 1px #ffffff4d;transform:translateY(-2px)}.generate-btn:active{transform:translateY(1px);box-shadow:0 4px 12px #3b82f633}.primary-btn{background:#3b82f6;color:#fff;padding:11px 16px;box-shadow:0 4px 12px #3b82f640}.secondary-btn{background:#eef2ff;color:#1e3a8a;padding:10px 14px;border:1px solid #dbeafe}.ghost-btn{background:transparent;color:var(--muted);border:1px solid var(--border);padding:10px 14px}.ghost-btn.small{padding:7px 10px;font-size:12px}.ghost-btn.danger{color:var(--error);border-color:#fecaca}.icon-btn{width:38px;height:38px;background:var(--surface-soft);color:var(--muted);font-size:22px}.uploader{width:100%}.dropzone{border:1.5px dashed var(--border-strong);border-radius:14px;min-height:128px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;background:var(--surface-soft);color:var(--muted);text-align:center;cursor:pointer}.dropzone.compact{min-height:86px;margin-bottom:10px}.dropzone input{display:none}.dropzone-icon{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#fff;border:1px solid var(--border);color:var(--primary-2);font-size:24px}.dropzone small{color:var(--muted-2)}.upload-preview{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fff}.upload-preview img{width:100%;display:block;max-height:220px;object-fit:cover}.upload-meta{display:flex;justify-content:space-between;gap:10px;padding:10px;color:var(--muted);font-size:12px}.upload-meta strong{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-preview .ghost-btn{margin:0 10px 10px;width:calc(100% - 20px)}.upload-list{display:flex;flex-direction:column;gap:8px}.upload-item{display:grid;grid-template-columns:58px minmax(0,1fr) auto;gap:10px;align-items:center;padding:8px;border:1px solid var(--border);border-radius:12px;background:#fff}.upload-item img{width:58px;height:58px;object-fit:cover;border-radius:9px;background:var(--surface-soft)}.upload-item-info{min-width:0;display:flex;flex-direction:column;gap:3px}.upload-item-info strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.upload-item-info span{color:var(--muted);font-size:12px}.mini-danger-btn{border:1px solid #fecaca;color:var(--error);background:#fff7f7;border-radius:9px;padding:7px 9px;font-size:12px;font-weight:700}.canvas-area{min-height:calc(100vh - 106px);padding:18px}.canvas-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.canvas-header h2,.history-header h2{margin:0;font-size:18px}.canvas-header p,.history-header p{margin:4px 0 0;font-size:12px;color:var(--muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:520px;border:1px dashed var(--border);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fafc);color:var(--muted)}.empty-card{padding:24px 34px;border:1px solid var(--border);border-radius:999px;background:#fff}.result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.result-card{position:relative;min-height:240px;overflow:hidden;border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1);transform:translateY(0)}.result-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:#cbd5e180}.result-card img{width:100%;height:auto;display:block}.result-card.is-loading{min-height:280px;display:grid;place-items:center}.skeleton{color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:12px}.spinner{width:28px;height:28px;border:3px solid #dbeafe;border-top-color:#2563eb;border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.card-toolbar{position:absolute;left:0;right:0;bottom:0;display:flex;gap:8px;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.5);border-radius:0 0 18px 18px;padding:12px 10px;opacity:0;transform:translateY(100%);transition:all .3s cubic-bezier(.16,1,.3,1)}.result-card:hover .card-toolbar{opacity:1;transform:translateY(0)}.card-toolbar button{flex:1;border:0;border-radius:10px;background:var(--primary);color:#fff;padding:8px 6px;font-size:12px;font-weight:600}.floating-actions{position:absolute;top:10px;right:10px;display:flex;gap:8px;align-items:center;opacity:0;transform:translateY(-6px);transition:.15s ease}.result-card:hover .floating-actions{opacity:1;transform:translateY(0)}.zoom-btn{width:36px;height:36px;border:0;border-radius:12px;background:#0f172ac2;color:#fff;display:grid;place-items:center;font-size:18px;line-height:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.zoom-btn:hover{background:#2563ebe6}.url-copy-btn{height:36px;border:0;border-radius:12px;background:#2563ebe6;color:#fff;padding:0 11px;font-size:12px;font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.url-copy-btn:disabled{background:#0f172a94;cursor:wait}.url-copy-btn.error{background:#dc2626e6;cursor:pointer}.card-meta{display:block;padding:8px 10px;color:var(--muted)}.error-card{min-height:240px;padding:18px;display:flex;flex-direction:column;justify-content:center;gap:8px;color:var(--error);background:#fef2f2}.error-card p{margin:0;color:#991b1b}.preview-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;background:#0f172ae0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center}.preview-dialog{position:relative;width:100vw;height:100vh;box-sizing:border-box;padding:58px 28px 34px;display:flex;align-items:center;justify-content:center}.preview-dialog img{max-width:100%;max-height:100%;object-fit:contain;display:block;border-radius:12px;box-shadow:0 24px 80px #00000059}.preview-close{position:absolute;top:18px;right:22px;width:42px;height:42px;border:0;border-radius:50%;background:#fff;color:#111827;font-size:26px;box-shadow:var(--shadow-lg)}.preview-info{position:absolute;left:50%;top:18px;transform:translate(-50%);display:flex;align-items:center;gap:8px;max-width:calc(100vw - 120px);overflow:auto}.preview-info span{padding:8px 12px;border-radius:999px;background:#ffffffeb;color:#0f172a;font-size:13px;font-weight:800;white-space:nowrap}.preview-actions{position:absolute;left:50%;bottom:22px;transform:translate(-50%);display:flex;gap:10px;z-index:1}.preview-actions button{border:0;border-radius:999px;padding:10px 16px;background:#fffffff0;color:#0f172a;font-size:13px;font-weight:800;box-shadow:var(--shadow-lg)}.preview-actions button:hover{background:#dbeafe;color:#1d4ed8}.task-queue{display:flex;flex-direction:column;gap:14px}.task-queue-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:14px;background:var(--surface-soft);color:var(--muted);font-size:13px;font-weight:700}.task-toolbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.task-stack{display:flex;flex-direction:column;gap:14px}.task-card{border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fafc);padding:14px}.task-card.status-running{border-color:#bfdbfe}.task-card.status-failed{border-color:#fecaca}.task-header{display:flex;justify-content:space-between;gap:14px;margin-bottom:12px}.task-title{min-width:0;flex:1}.task-title strong{display:block;font-size:14px}.task-title p{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;color:var(--muted);font-size:12px;white-space:nowrap}.status-pill{border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800;background:#eef2ff;color:#1e3a8a}.status-pill.running{background:#dbeafe;color:#1d4ed8}.status-pill.completed{background:#dcfce7;color:#166534}.status-pill.failed{background:#fee2e2;color:#991b1b}.task-error{border:1px solid #fecaca;background:#fef2f2;color:#991b1b;border-radius:12px;padding:10px 12px;margin-bottom:12px;font-size:13px}.history-panel{padding:16px;max-height:calc(100vh - 106px);overflow:hidden;position:sticky;top:18px;display:flex;flex-direction:column}.history-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.history-header-actions{display:flex;gap:8px;align-items:center}.history-panel.collapsed{padding:10px;align-items:stretch;min-height:150px}.history-expand-btn{border:1px dashed var(--border);border-radius:16px;background:linear-gradient(180deg,#fff,#f8fafc);color:var(--primary);min-height:130px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-weight:800}.history-expand-btn small{color:var(--muted);font-size:12px}.history-empty{border:1px dashed var(--border);border-radius:14px;padding:28px;color:var(--muted);text-align:center}.history-list{display:flex;flex-direction:column;gap:12px;overflow:auto;padding-right:4px}.history-item{border:1px solid var(--border);background:#fff;border-radius:14px;padding:10px}.history-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px}.history-thumb-card{position:relative;border-radius:10px;overflow:hidden;background:var(--surface-soft);aspect-ratio:1}.history-thumb-image{width:100%;height:100%;border:0;padding:0;background:transparent;display:block}.history-thumb-image img{width:100%;height:100%;object-fit:cover;display:block}.history-more-badge{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0f172a8a;color:#fff;font-size:18px;font-weight:900}.history-thumb-actions{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-end;gap:4px;padding:5px;background:linear-gradient(180deg,transparent 20%,rgba(15,23,42,.72));opacity:0;transition:.15s ease}.history-thumb-card:hover .history-thumb-actions{opacity:1}.history-thumb-actions button{border:0;border-radius:8px;background:#ffffffeb;color:#0f172a;padding:4px 5px;font-size:11px;font-weight:800}.history-info p{margin:0 0 4px;font-size:13px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.history-info small{color:var(--muted)}.history-actions{display:flex;gap:8px;margin-top:10px}.history-actions button{flex:1;border:1px solid var(--border);background:var(--surface-soft);color:var(--muted);border-radius:10px;padding:8px;font-size:12px}.toast{position:fixed;top:86px;left:50%;transform:translate(-50%);z-index:30;max-width:min(720px,calc(100vw - 36px));border-radius:999px;border:1px solid var(--border);background:#fffffff5;box-shadow:var(--shadow-md);padding:10px 12px 10px 16px;display:flex;align-items:center;gap:12px;color:var(--text)}.toast.ok{border-color:#bbf7d0;color:#166534}.toast.error{border-color:#fecaca;color:#991b1b}.toast button{border:0;background:transparent;color:inherit;font-size:18px}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0f172a6b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:18px}.settings-modal{width:min(760px,100%);background:#fff;border-radius:20px;box-shadow:0 28px 80px #0f172a38;overflow:hidden}.modal-header{display:flex;align-items:start;justify-content:space-between;gap:18px;padding:22px 22px 16px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0}.modal-header p{margin:4px 0 0;color:var(--muted);font-size:13px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:18px 22px;max-height:68vh;overflow:auto}.field.full,.check-field.full,.settings-note.full{grid-column:1 / -1}.field small{display:block;margin-top:6px;color:var(--muted)}.inline-input{display:flex;gap:8px}.inline-input input{flex:1}.check-field{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}.check-field input{width:auto}.settings-note{display:block;margin-top:-8px;color:var(--muted-2);font-size:12px;line-height:1.5}.modal-actions{display:flex;align-items:center;gap:10px;padding:16px 22px 22px;border-top:1px solid var(--border)}.spacer{flex:1}@media(max-width:1220px){.workspace,.workspace.history-collapsed{grid-template-columns:320px 1fr}.history-panel{grid-column:1 / -1;position:static;max-height:none}.history-panel.collapsed{min-height:auto}.history-expand-btn{min-height:58px;flex-direction:row}}@media(max-width:820px){.app-shell{padding:12px}.topbar{height:auto;flex-direction:column;align-items:stretch}.top-actions{justify-content:space-between}.workspace,.workspace.history-collapsed{grid-template-columns:1fr}.sidebar{position:static}.settings-grid{grid-template-columns:1fr}.ratio-list{grid-template-columns:repeat(3,1fr)}.resolution-list{grid-template-columns:repeat(2,1fr)}.config-pill{align-items:flex-start}.task-header{flex-direction:column}.task-meta{align-items:flex-start;white-space:normal}}@media(max-width:820px),(hover:none),(pointer:coarse){.result-card .floating-actions{opacity:1;transform:none}.result-card .card-toolbar{position:static;opacity:1;transform:none;padding:10px;background:#fff}.card-toolbar button{background:#111827}.history-thumb-card .history-thumb-actions{opacity:1}.preview-dialog{padding-bottom:calc(92px + env(safe-area-inset-bottom))}.preview-actions{bottom:calc(22px + env(safe-area-inset-bottom))}.toast{top:calc(12px + env(safe-area-inset-top));border-radius:18px}}
