:root{color-scheme:light;font-family:Microsoft YaHei,PingFang SC,Segoe UI,sans-serif;background:#f7f7f8;color:#111827;line-height:1.5;font-weight:400}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.app{min-height:100vh;height:100vh;display:flex;flex-direction:column;overflow:hidden;background:#f7f7f8;color:#111827;transition:background .18s ease,color .18s ease}.app.dark{color-scheme:dark;background:#121212;color:#f3f4f6}.topbar{height:68px;flex:none;display:grid;grid-template-columns:260px 1fr 360px;align-items:center;padding:0 28px;border-bottom:1px solid #e5e7eb;background:#f7f7f8;position:relative;z-index:10}.dark .topbar{background:#1a1a1a;border-color:#2f3136}.brand{display:inline-flex;align-items:center;gap:10px;font-size:20px;font-weight:800;color:#1f2937;white-space:nowrap;width:fit-content}.dark .brand{color:#f9fafb}.brand-mark{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;color:#fff;font-weight:900;background:linear-gradient(135deg,#22c55e,#10b981);box-shadow:0 8px 22px #22c55e40}.topnav{display:flex;justify-content:center;gap:34px}.nav-item{position:relative;padding:22px 0 19px;border:0;background:transparent;color:#111827;font-size:15px;font-weight:500}.dark .nav-item{color:#e5e7eb}.nav-item:after{content:"";position:absolute;left:0;right:0;bottom:16px;height:2px;transform:scaleX(0);transform-origin:left;background:#22c55e;transition:transform .18s ease}.nav-item:hover,.nav-item.active{color:#22c55e}.nav-item:hover:after,.nav-item.active:after{transform:scaleX(1)}.nav-text{position:relative;display:inline-flex}.nav-text i{width:8px;height:8px;border-radius:999px;background:#ef4444;position:absolute;right:-10px;top:-5px}.top-actions{justify-self:end;display:flex;align-items:center;gap:12px}.icon-button,.mobile-icon{border:0;background:transparent;color:#4b5563;border-radius:999px;width:36px;height:36px;display:grid;place-items:center}.icon-button:hover,.mobile-icon:hover{background:#eef2f2}.dark .icon-button,.dark .mobile-icon{color:#d1d5db}.dark .icon-button:hover,.dark .mobile-icon:hover{background:#2a2b32}.mobile-icon{display:none}.points{height:34px;border:0;border-radius:8px;padding:0 12px;display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600}.points.ghost{color:#4b5563;background:transparent}.points.ghost:hover{background:#eef2f2}.points.primary{color:#fff;background:#22c55e;box-shadow:0 6px 18px #22c55e38}.points.primary:hover{background:#16a34a}.dark .points.ghost{color:#d1d5db}.dark .points.ghost:hover{background:#2a2b32}.app-main{flex:1;min-height:0;overflow:hidden}.workbench{height:100%;min-height:0;display:grid;grid-template-columns:340px 1fr;background:#f9fafb}.dark .workbench{background:#121212}.image-panel{min-height:0;display:flex;flex-direction:column;border-right:1px solid #e5e7eb;background:#fff}.dark .image-panel{background:#202123;border-color:#2f3136}.panel-scroll{overflow-y:auto;padding:18px 16px;flex:1;min-height:0}.panel-section{border-bottom:1px solid #eef2f4;padding:0 0 18px;margin-bottom:18px}.panel-section.compact{border-bottom:0}.dark .panel-section{border-color:#2a2b32}.section-title{margin:0 0 12px;color:#374151;font-size:14px;font-weight:800;display:flex;align-items:center;gap:8px}.dark .section-title{color:#e5e7eb}.field{display:block;margin-bottom:12px}.field-label{display:block;padding:0 2px;margin-bottom:6px;color:#6b7280;font-size:12px;font-weight:600}.dark .field-label{color:#9ca3af}.select-wrap{position:relative}.select-wrap select{width:100%;appearance:none;border:1px solid #e5e7eb;background:#f9fafb;color:#111827;border-radius:8px;padding:10px 36px 10px 12px;font-size:14px;outline:none}.select-wrap svg{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.select-wrap select:focus{border-color:#22c55e8c;box-shadow:0 0 0 3px #22c55e21}.dark .select-wrap select{color:#f3f4f6;background:#2a2b32;border-color:#374151}.segmented,.stepper{display:flex;gap:4px;padding:4px;border-radius:9px;background:#f3f4f6}.dark .segmented,.dark .stepper{background:#2a2b32}.segmented button,.stepper button{flex:1;min-height:30px;border:0;border-radius:7px;background:transparent;color:#6b7280;font-size:12px;font-weight:700}.segmented button.active,.stepper button.active{color:#16a34a;background:#fff;box-shadow:0 1px 4px #0f172a14}.dark .segmented button.active,.dark .stepper button.active{color:#4ade80;background:#1f2937}.ratio-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.ratio-grid button{border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;color:#4b5563;min-height:40px;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:700}.ratio-grid button span{width:16px;border:1px solid currentColor;border-radius:1px}.ratio-grid button.active{border-color:#22c55e;color:#16a34a;background:#f0fdf4}.dark .ratio-grid button{background:#2a2b32;border-color:#374151;color:#d1d5db}.dark .ratio-grid button.active{background:#22c55e24;color:#4ade80;border-color:#22c55e}.cost-line,.hint{color:#9a6700;font-size:12px}.hint{margin:-2px 0 10px;line-height:1.45}.dark .hint,.dark .cost-line{color:#f59e0b}.upload-zone{width:100%;min-height:68px;border:1px dashed #cbd5e1;border-radius:10px;background:#f9fafb;color:#64748b;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.upload-zone:hover{color:#16a34a;border-color:#22c55e;background:#f0fdf4}.dark .upload-zone{background:#2a2b32;border-color:#374151;color:#d1d5db}.dark .upload-zone:hover{background:#22c55e1c}.hidden-input{display:none}.reference-grid{margin-top:10px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.reference-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#f3f4f6}.reference-item img{width:100%;height:100%;object-fit:cover;display:block}.reference-item button{position:absolute;top:4px;right:4px;width:20px;height:20px;border:0;border-radius:999px;display:grid;place-items:center;color:#fff;background:#0f172ac7}.row-between{display:flex;align-items:center;justify-content:space-between;gap:10px}.tiny-button{border:1px solid #dcfce7;border-radius:7px;background:#f0fdf4;color:#16a34a;display:inline-flex;align-items:center;gap:4px;padding:4px 7px;font-size:12px;font-weight:700}.dark .tiny-button{background:#22c55e1f;border-color:#22c55e47;color:#4ade80}.prompt-input{width:100%;min-height:250px;resize:vertical;border:1px solid #e5e7eb;border-radius:12px;background:#f9fafb;color:#111827;padding:12px;outline:none;font-size:14px}.prompt-input:focus{border-color:#22c55e8c;box-shadow:0 0 0 3px #22c55e1f}.dark .prompt-input{background:#2a2b32;color:#f3f4f6;border-color:#374151}.sample-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}.sample-row button{border:1px solid #e5e7eb;border-radius:7px;background:#fff;color:#64748b;font-size:11px;min-height:30px}.sample-row button:hover{color:#16a34a;border-color:#bbf7d0}.dark .sample-row button{background:#202123;color:#d1d5db;border-color:#374151}.generate-footer{flex:none;padding:14px 16px 16px;border-top:1px solid #e5e7eb;background:#fff}.dark .generate-footer{background:#202123;border-color:#2f3136}.error-line{padding:8px 10px;margin-bottom:10px;border-radius:8px;color:#b91c1c;background:#fef2f2;font-size:12px}.dark .error-line{color:#fca5a5;background:#7f1d1d40}.generate-btn{width:100%;min-height:48px;border:0;border-radius:12px;color:#fff;background:linear-gradient(90deg,#16a34a,#10b981);box-shadow:0 14px 28px #22c55e38;font-weight:900;display:flex;align-items:center;justify-content:center;gap:8px}.generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 34px #22c55e40}.generate-btn:disabled{opacity:.55}.generate-btn.busy svg{animation:spin 1.2s linear infinite}.btn-cost{font-size:12px;opacity:.8}.preview-panel{min-width:0;min-height:0;background:#f9fafb}.dark .preview-panel{background:#121212}.preview-scroll{height:100%;overflow-y:auto;padding:24px;display:flex;flex-direction:column}.preview-stage{flex:1;min-height:420px;border:2px dashed #e5e7eb;border-radius:16px;background:#ffffffb8;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.preview-stage.has-image{border-style:solid;border-color:#dcfce7;background:#fff;padding:16px}.dark .preview-stage{background:#1a1a1ab3;border-color:#1f2937}.dark .preview-stage.has-image{background:#1a1a1a;border-color:#14532d}.preview-stage img{width:100%;height:100%;max-height:68vh;object-fit:contain;display:block;border-radius:12px}.preview-meta{position:absolute;left:28px;bottom:28px;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;color:#111827;background:#ffffffe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 28px #0f172a1f;font-size:12px;font-weight:700}.preview-meta span{color:#16a34a}.empty-preview{text-align:center;color:#6b7280;padding:20px}.empty-preview h3{margin:18px 0 8px;color:#111827;font-size:18px}.empty-preview p{max-width:360px;margin:0 auto;font-size:14px}.dark .empty-preview h3{color:#fff}.empty-icon,.placeholder-icon{width:80px;height:80px;border-radius:999px;display:grid;place-items:center;margin:0 auto;color:#9ca3af;background:#f3f4f6;box-shadow:inset 0 2px 8px #0f172a0f}.dark .empty-icon,.dark .placeholder-icon{background:#2a2b32}.pulse{animation:pulse 1.4s ease-in-out infinite}.task-strip{margin-top:14px;display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.task-pill{min-width:118px;border-radius:999px;padding:7px 10px;color:#64748b;background:#fff;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;font-weight:800}.task-pill.processing{color:#047857;border-color:#bbf7d0;background:#f0fdf4}.task-pill.error{color:#b91c1c;border-color:#fecaca;background:#fef2f2}.task-pill small{color:#94a3b8;font-size:10px}.history-head{margin-top:24px;display:flex;align-items:center;justify-content:space-between;gap:14px}.history-title{display:flex;align-items:center;gap:8px;color:#111827}.history-title h3{margin:0;font-size:16px}.dark .history-title{color:#fff}.refresh-button{border:1px solid #bbf7d0;border-radius:7px;padding:5px 8px;color:#15803d;background:#f0fdf4;display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:800}.history-actions{display:flex;align-items:center;gap:8px}.history-actions button,.link-button{border:1px solid #e5e7eb;border-radius:8px;min-height:32px;padding:0 10px;display:inline-flex;align-items:center;gap:5px;background:#fff;color:#4b5563;font-size:12px;font-weight:800}.history-actions button:disabled{opacity:.4}.history-actions .success{border:0;background:#16a34a;color:#fff}.history-actions .danger{border:0;background:#dc2626;color:#fff}.history-actions .link-button{color:#16a34a;border:0;background:transparent}.dark .history-actions button{color:#d1d5db;background:#1f2937;border-color:#374151}.dark .history-actions .success,.dark .history-actions .danger{color:#fff}.dark .history-actions .link-button{color:#4ade80;background:transparent}.history-grid{display:grid;grid-auto-flow:column;grid-auto-columns:112px;gap:12px;overflow-x:auto;margin-top:14px;padding:2px 0 8px}.history-card{position:relative;border:2px solid transparent;border-radius:10px;padding:0;overflow:hidden;background:#e5e7eb;aspect-ratio:1;text-align:left}.history-card:hover,.history-card.selected{border-color:#22c55e}.history-card img{width:100%;height:100%;object-fit:cover;display:block}.history-card span{position:absolute;left:6px;right:6px;bottom:6px;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.65);font-size:10px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-card i{display:none;position:absolute;top:6px;right:6px;width:12px;height:12px;border:2px solid #ffffff;border-radius:999px;background:#22c55e}.history-card.selected i{display:block}.history-empty{text-align:center;color:#9ca3af;margin:20px 0 4px;font-size:12px}.prompt-page{height:100%;display:grid;grid-template-columns:255px 1fr;background:#f7f7f8}.dark .prompt-page{background:#121212}.prompt-sidebar{position:relative;border-right:1px solid #e5e7eb;background:#fff;padding:24px}.dark .prompt-sidebar{background:#1a1a1a;border-color:#2f3136}.prompt-sidebar h2{margin:0 0 20px;display:flex;align-items:center;gap:8px;font-size:18px}.prompt-sidebar h3{margin:30px 0 14px;font-size:18px}.prompt-menu{width:100%;min-height:44px;border:0;border-radius:12px;background:transparent;color:#334155;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 14px;font-size:14px;font-weight:800}.prompt-menu.active{justify-content:flex-start;color:#16a34a;background:#ecfdf3}.prompt-menu.muted:hover{background:#f3f4f6}.dark .prompt-menu{color:#d1d5db}.dark .prompt-menu.active{color:#4ade80;background:#22c55e1f}.data-source{position:absolute;left:24px;right:24px;bottom:22px;color:#94a3b8;font-size:12px}.prompt-content{overflow-y:auto;padding:34px 40px}.prompt-content>header{max-width:896px;margin:0 auto 30px}.prompt-content h1{margin:0 0 4px;font-size:28px;line-height:1.2}.prompt-content p{margin:0;color:#64748b}.prompt-builder{max-width:896px;margin:0 auto;border:1px solid #bbf7d0;border-radius:16px;padding:16px;background:linear-gradient(135deg,#f0fdf4d1,#fff);box-shadow:0 1px 2px #0f172a0a}.dark .prompt-builder{background:linear-gradient(135deg,#052e1638,#23242b);border-color:#14532d}.builder-top{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.builder-top strong{font-size:14px}.builder-top p{margin-top:4px;font-size:12px}.steps{flex:none;display:flex;gap:4px;padding:4px;border:1px solid #dcfce7;border-radius:9px;background:#ffffffbd}.steps button{border:0;border-radius:6px;background:transparent;color:#64748b;padding:7px 10px;font-size:11px;font-weight:800}.steps button.active{color:#fff;background:#16a34a}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:18px}.category-card{min-height:78px;border:1px solid #e5e7eb;border-radius:10px;background:#ffffffc7;color:#0f172a;padding:12px;text-align:left}.category-card strong{display:block;font-size:13px;margin-bottom:6px}.category-card span{display:block;color:#64748b;font-size:11px;line-height:1.45}.category-card.active{border-color:#22c55e;box-shadow:0 0 0 1px #22c55e0d}.dark .category-card{background:#1f2937b8;border-color:#374151;color:#f3f4f6}.dark .category-card.active{border-color:#22c55e}.prompt-preview{margin-top:16px;border:1px solid #e5e7eb;border-radius:10px;background:#ffffffc2;padding:12px}.dark .prompt-preview{background:#1f293780;border-color:#374151}.prompt-preview span{color:#94a3b8;font-size:12px}.prompt-preview textarea{width:100%;min-height:132px;margin-top:10px;resize:vertical;border:0;outline:none;background:transparent;color:inherit;font-size:13px}.builder-actions{margin-top:16px;display:flex;justify-content:flex-end;gap:10px}.builder-actions button{min-height:36px;border:1px solid #bbf7d0;border-radius:9px;background:#fff;color:#15803d;padding:0 12px;display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:800}.builder-actions button.primary{border:0;color:#fff;background:#16a34a}.builder-actions button:disabled{color:#94a3b8;border-color:#e5e7eb}.logs-page{height:100%;overflow-y:auto;padding:34px;max-width:980px;margin:0 auto}.logs-page h1{text-align:center;margin:0 0 28px}.log-list{display:grid;gap:18px}.log-card{border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:22px;box-shadow:0 8px 22px #0f172a0a}.log-card h2{margin:0 0 8px;font-size:18px}.log-card p{margin:0 0 12px;color:#64748b}.log-card time{color:#94a3b8;font-size:12px}.placeholder-page{height:100%;display:grid;place-content:center;text-align:center;gap:10px;color:#64748b}.placeholder-page h1{margin:12px 0 0;color:#111827}.dark .placeholder-page h1{color:#fff}.payment-result-page{min-height:100%;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#f0fdf4b8,#ffffffdb),#f7f7f8}.dark .payment-result-page{background:linear-gradient(135deg,#14532d2e,#1f293733),#121212}.payment-result-card{width:min(480px,100%);border:1px solid #dbe7df;border-radius:14px;background:#fff;padding:26px;text-align:center;box-shadow:0 24px 70px #0f172a29}.dark .payment-result-card{background:#202123;border-color:#374151}.payment-result-icon{width:80px;height:80px;margin:0 auto 16px;border-radius:999px;display:grid;place-items:center;color:#16a34a;background:#f0fdf4}.payment-result-card.error .payment-result-icon,.payment-result-card.login .payment-result-icon{color:#dc2626;background:#fef2f2}.payment-result-card.pending .payment-result-icon,.payment-result-card.loading .payment-result-icon{color:#d97706;background:#fffbeb}.dark .payment-result-icon{background:#14532d47}.payment-result-card h1{margin:0 0 8px;font-size:24px}.payment-result-card p{margin:0;color:#64748b;font-size:14px}.dark .payment-result-card p{color:#9ca3af}.payment-result-detail{margin-top:20px;border:1px solid #e5e7eb;border-radius:10px;padding:12px;display:grid;grid-template-columns:80px 1fr;gap:8px 12px;text-align:left;font-size:13px}.payment-result-detail span{color:#94a3b8}.payment-result-detail strong{min-width:0;overflow-wrap:anywhere;color:#111827}.dark .payment-result-detail{border-color:#374151}.dark .payment-result-detail strong{color:#f3f4f6}.payment-result-actions{margin-top:22px;display:flex;justify-content:center;gap:10px}.payment-result-actions button{min-height:38px;border:1px solid #bbf7d0;border-radius:9px;background:#fff;color:#15803d;padding:0 14px;display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:900}.payment-result-actions button.primary{border:0;color:#fff;background:#16a34a}.dark .payment-result-actions button{background:#1f2937;border-color:#14532d;color:#86efac}.dark .payment-result-actions button.primary{color:#fff;background:#16a34a}.modal-backdrop{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:18px;background:#0f172a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.auth-modal,.recharge-modal{width:min(440px,100%);border:1px solid #dbe7df;border-radius:14px;background:#fff;padding:18px;box-shadow:0 24px 70px #0f172a3d}.recharge-modal{width:min(680px,100%)}.dark .auth-modal,.dark .recharge-modal{background:#202123;border-color:#374151}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.modal-head h2{margin:0;font-size:20px}.modal-head p{margin:5px 0 0;color:#64748b;font-size:13px}.dark .modal-head p{color:#9ca3af}.modal-head button{flex:none;width:32px;height:32px;border:0;border-radius:999px;background:#f3f4f6;color:#64748b;display:grid;place-items:center}.dark .modal-head button{background:#2a2b32;color:#d1d5db}.modal-field{display:block;margin-bottom:12px}.modal-field span{display:block;margin-bottom:6px;color:#475569;font-size:13px;font-weight:800}.dark .modal-field span{color:#d1d5db}.modal-field input{width:100%;min-height:42px;border:1px solid #e5e7eb;border-radius:9px;background:#f9fafb;color:#111827;padding:0 12px;outline:none}.modal-field input:focus{border-color:#22c55e8c;box-shadow:0 0 0 3px #22c55e1f}.dark .modal-field input{color:#f3f4f6;background:#2a2b32;border-color:#374151}.code-field div{display:grid;grid-template-columns:1fr 116px;gap:8px}.code-field button,.modal-primary{min-height:42px;border:0;border-radius:9px;color:#fff;background:#16a34a;font-weight:900}.code-field button:disabled,.modal-primary:disabled{opacity:.55}.modal-primary{width:100%;margin-top:4px}.modal-message{border-radius:9px;margin:10px 0;padding:9px 10px;color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;font-size:13px}.dark .modal-message{color:#86efac;background:#14532d40;border-color:#166534}.package-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.package-card{min-height:148px;border:1px solid #dcfce7;border-radius:12px;background:linear-gradient(180deg,#fff,#f0fdf4);color:#14532d;padding:14px;display:flex;flex-direction:column;align-items:flex-start;text-align:left}.package-card:hover{border-color:#22c55e;box-shadow:0 12px 28px #22c55e29}.package-card strong{font-size:15px}.package-card span{margin-top:12px;font-size:22px;font-weight:900}.package-card em{margin-top:4px;color:#16a34a;font-style:normal;font-weight:800}.package-card small{margin-top:auto;color:#64748b;font-size:12px}.dark .package-card{background:linear-gradient(180deg,#1f2937,#14532d47);border-color:#14532d;color:#ecfdf5}.disabled-panel{opacity:.88}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.55;transform:scale(.98)}}@media(max-width:1080px){.topbar{grid-template-columns:220px 1fr auto;padding:0 16px}.topnav{gap:18px}.points.login,.points.ghost span{display:none}.workbench{grid-template-columns:310px 1fr}}@media(max-width:860px){.app{height:auto;min-height:100vh;overflow:auto}.topbar{height:auto;min-height:62px;grid-template-columns:auto 1fr auto}.mobile-icon{display:grid}.brand{justify-self:center;font-size:16px}.brand-mark,.topnav,.top-actions .points,.top-actions .icon-button{display:none}.app-main{overflow:visible}.workbench,.prompt-page{height:auto;min-height:calc(100vh - 62px);grid-template-columns:1fr}.image-panel{border-right:0;border-bottom:1px solid #e5e7eb}.panel-scroll{max-height:none}.preview-scroll{min-height:620px;padding:16px}.history-head,.builder-top{flex-direction:column;align-items:stretch}.history-actions{flex-wrap:wrap}.prompt-sidebar{display:none}.prompt-content{padding:24px 16px}.category-grid{grid-template-columns:repeat(2,1fr)}.package-grid{grid-template-columns:1fr}.steps{overflow-x:auto}}@media(max-width:520px){.category-grid,.sample-row{grid-template-columns:1fr}.ratio-grid{grid-template-columns:repeat(2,1fr)}}
