*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2F6BFF;--primary-light: #EBF0FF;--bg: #F5F7FA;--card: #FFFFFF;--text: #1A1A2E;--text-secondary: #6B7280;--border: #E5E7EB;--radius: 12px;--danger: #EF4444;--success: #10B981}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{max-width:480px;margin:0 auto;min-height:100vh}.loading-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--card);border-bottom:1px solid var(--border)}.header h1{font-size:18px;font-weight:600}.user-info{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.avatar{width:28px;height:28px;border-radius:50%}.tabs{display:flex;background:var(--card);border-bottom:1px solid var(--border);padding:0 20px}.tab{flex:1;padding:12px 0;border:none;background:none;font-size:14px;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.panel{padding:20px}.chat-entry{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius);cursor:pointer;margin-bottom:12px;text-decoration:none;color:#fff;transition:opacity .2s}.chat-entry:active{opacity:.85}.chat-entry-icon{font-size:28px;flex-shrink:0}.chat-entry-body{flex:1;display:flex;flex-direction:column;gap:2px}.chat-entry-title{font-size:16px;font-weight:600}.chat-entry-desc{font-size:12px;opacity:.85}.chat-entry-arrow{font-size:24px;font-weight:700;opacity:.7}.inspire-entry{display:flex;align-items:center;gap:8px;padding:12px 14px;background:linear-gradient(135deg,#ebf0ff,#f0e6ff);border-radius:var(--radius);cursor:pointer;margin-bottom:20px;transition:opacity .2s}.inspire-entry:active{opacity:.8}.inspire-entry-icon{font-size:18px}.inspire-entry span:nth-child(2){flex:1;font-size:14px;color:#4338ca}.inspire-entry-arrow{font-size:20px;color:#4338ca;font-weight:700}.field{margin-bottom:20px}.field label{display:block;font-size:14px;font-weight:500;margin-bottom:8px}textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;resize:none;font-family:inherit;outline:none;transition:border-color .2s}textarea:focus{border-color:var(--primary)}.template-list{display:flex;gap:10px}.tpl-btn{flex:1;padding:12px;border:2px solid var(--border);border-radius:var(--radius);background:var(--card);cursor:pointer;text-align:left;transition:all .2s;display:flex;flex-direction:column;gap:4px}.tpl-btn.active{border-color:var(--primary);background:var(--primary-light)}.tpl-name{font-size:14px;font-weight:600}.tpl-desc{font-size:12px;color:var(--text-secondary)}.layout-field-hint{font-size:12px;color:var(--text-secondary);margin:4px 0 8px}.layout-list{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}.layout-list::-webkit-scrollbar{display:none}.layout-card{flex:0 0 110px;border:2px solid var(--border);border-radius:var(--radius);background:var(--card);cursor:pointer;transition:all .2s;overflow:hidden}.layout-card.active{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}.layout-preview-wrap{display:block;width:100%;padding:0;margin:0;border:none;background:#f5f5f5;cursor:zoom-in;-webkit-tap-highlight-color:transparent}.layout-preview{width:100%;height:130px;object-fit:cover;display:block}.layout-text{padding:6px 8px;text-align:center}.layout-name{font-size:13px;font-weight:600;display:block}.layout-card.active .layout-name{color:var(--primary)}.layout-desc{font-size:10px;color:var(--text-secondary);line-height:1.3;display:block;margin-top:2px}.layout-zoom-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#000000c7;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));box-sizing:border-box}.layout-zoom-panel{position:relative;max-width:min(520px,100%);max-height:90vh;background:var(--card);border-radius:12px;padding:14px 14px 18px;overflow:auto;box-shadow:0 8px 32px #00000059}.layout-zoom-close{position:absolute;top:8px;right:10px;width:36px;height:36px;border:none;border-radius:50%;background:#00000014;font-size:22px;line-height:1;cursor:pointer;color:var(--text)}.layout-zoom-title{font-size:16px;font-weight:600;margin:0 40px 6px 0}.layout-zoom-desc{font-size:12px;color:var(--text-secondary);margin:0 0 12px}.layout-zoom-img{width:100%;height:auto;max-height:min(72vh,640px);object-fit:contain;display:block;border-radius:8px;background:#eee}.size-list{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.size-btn{padding:8px 6px;border:1px solid var(--border);border-radius:10px;background:var(--card);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:2px}.size-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.size-label{font-size:13px;font-weight:500}.size-desc{font-size:10px;opacity:.7}.size-btn.active .size-desc{opacity:.9}.custom-size{display:flex;align-items:center;gap:8px;margin-top:10px}.custom-size input{width:90px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:14px;text-align:center;outline:none}.custom-size input:focus{border-color:var(--primary)}.custom-size span{color:var(--text-secondary);font-size:14px}.size-hint{font-size:12px;color:var(--text-secondary)}.quality-list{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.quality-btn{padding:10px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:2px}.quality-btn.active{border-color:var(--primary);background:var(--primary-light)}.quality-name{font-size:14px;font-weight:600}.quality-btn.active .quality-name{color:var(--primary)}.quality-desc{font-size:11px;color:var(--text-secondary)}.ref-tips{background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius);margin-bottom:10px;overflow:hidden}.ref-tips-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;cursor:pointer;font-size:14px}.ref-tips-toggle{font-size:12px;color:var(--primary)}.ref-tips-body{padding:0 14px 12px;font-size:13px;line-height:1.8}.ref-tip-main{font-size:13px;margin-bottom:8px}.ref-tip-section{margin-top:8px;padding-top:8px;border-top:1px dashed #FDE68A}.ref-tip-subtitle{font-size:13px;font-weight:600;margin-bottom:4px;color:var(--text)}.ref-tip-row{display:flex;align-items:flex-start;gap:6px}.ref-tip-row b{color:var(--text)}.ref-tip-detail{font-size:12px;line-height:1.6;color:#92400e}.ref-tip-warn-section{background:#fef3c7;margin:8px -14px -12px;padding:10px 14px 12px;border-radius:0 0 var(--radius) var(--radius)}.ref-warn{font-size:12px;color:#d97706;margin-top:6px}.ref-gallery{display:flex;gap:10px;flex-wrap:wrap}.ref-thumb-wrap{position:relative;width:80px;height:80px;border-radius:10px;overflow:hidden}.ref-thumb{width:100%;height:100%;object-fit:cover}.ref-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:14px;line-height:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:24px;text-align:center;cursor:pointer;transition:border-color .2s;overflow:hidden}.upload-area-small{width:80px;height:80px;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px}.upload-text-small{font-size:12px;color:var(--text-secondary)}.upload-area:hover{border-color:var(--primary)}.upload-placeholder{color:var(--text-secondary)}.upload-icon{display:block;font-size:32px;color:var(--border);margin-bottom:2px}.preview-img{max-width:100%;max-height:200px;border-radius:8px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:none;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-generate{width:100%;padding:14px;font-size:16px;min-height:50px}.btn-download{display:block;text-align:center;margin-top:12px;background:var(--success);color:#fff;text-decoration:none;padding:12px;border-radius:var(--radius);font-size:14px}.btn-text{background:none;border:none;color:var(--danger);font-size:13px;cursor:pointer;margin-top:8px}.btn-retry{margin-top:10px;background:var(--primary);color:#fff;width:100%;padding:12px}.progress-wrap{margin-top:16px}.progress-bar{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#818CF8);border-radius:3px;transition:width .5s ease}.progress-text{text-align:center;font-size:13px;color:var(--text-secondary);margin-top:8px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.result{margin-top:20px}.result-img{width:100%;border-radius:var(--radius)}.result-blocked{padding:16px;background:#fff7ed;border-radius:var(--radius);color:#c2410c;font-weight:500;text-align:center}.result-error{padding:16px;background:#fef2f2;border-radius:var(--radius);color:var(--danger)}.category-tabs{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px}.category-tabs::-webkit-scrollbar{display:none}.cat-btn{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--card);font-size:13px;cursor:pointer;white-space:nowrap;transition:all .2s}.cat-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.inspire-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.inspire-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:0 1px 4px #0000000f;cursor:pointer;transition:transform .2s}.inspire-card:active{transform:scale(.97)}.inspire-img-wrap{width:100%;height:130px;overflow:hidden;background:#f0f0f0}.inspire-img{width:100%;height:100%;object-fit:cover}.inspire-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-light),#E0E7FF);font-size:28px;font-weight:700;color:var(--primary);opacity:.6}.inspire-text{padding:6px 8px;text-align:center}.inspire-title{font-size:12px;font-weight:600;display:block;line-height:1.3}.inspire-prompt{font-size:10px;color:var(--text-secondary);line-height:1.3;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.empty{text-align:center;padding:40px;color:var(--text-secondary)}.history-list{display:flex;flex-direction:column;gap:12px}.history-card{background:var(--card);border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;overflow:hidden;cursor:pointer;transition:box-shadow .2s}.history-card:active{box-shadow:0 2px 8px #0000001f}.history-row{display:flex;gap:12px;padding:12px;align-items:center}.history-img{width:64px;height:64px;border-radius:8px;object-fit:cover;flex-shrink:0}.history-info{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}.history-prompt{font-size:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.history-meta{display:flex;align-items:center;gap:8px;margin-top:4px}.history-time{font-size:12px;color:var(--text-secondary)}.history-status{font-size:11px;padding:1px 6px;border-radius:4px}.status-done{background:#d1fae5;color:#065f46}.status-failed{background:#fee2e2;color:#991b1b}.history-arrow{font-size:10px;color:var(--text-secondary);flex-shrink:0;padding:4px}.history-detail{padding:0 12px 16px;border-top:1px solid var(--border)}.history-preview{margin-top:12px}.history-full-img{width:100%;border-radius:var(--radius)}.history-prompt-full{margin-top:12px}.history-prompt-full label{font-size:12px;color:var(--text-secondary);display:block;margin-bottom:4px}.history-prompt-full p{font-size:13px;line-height:1.6;color:var(--text);word-break:break-all}.history-actions{margin-top:12px}.history-actions .btn-download{display:block}.result-timeout{padding:24px 16px;background:#fffbeb;border-radius:var(--radius);text-align:center;border:1px solid #FDE68A}.timeout-icon{font-size:40px;margin-bottom:8px}.timeout-title{font-size:16px;font-weight:600;color:#92400e;margin-bottom:6px}.timeout-desc{font-size:13px;color:#a16207;margin-bottom:16px;line-height:1.5}.btn-go-history{background:var(--primary);color:#fff;border:none;padding:10px 24px;border-radius:8px;font-size:14px;cursor:pointer}.result-error-actions{display:flex;gap:10px;margin-top:10px}.result-error-actions .btn{flex:1}.stats-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.stat-card{background:var(--card);padding:16px;border-radius:var(--radius);text-align:center;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;gap:4px}.stat-num{font-size:24px;font-weight:700;color:var(--primary)}.stat-label{font-size:12px;color:var(--text-secondary)}.stats-section{margin-top:20px}.stats-section h3{font-size:15px;margin-bottom:12px}.rank-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.rank-name{width:60px;font-size:13px;text-align:right;flex-shrink:0}.rank-bar{height:24px;background:var(--primary);border-radius:4px;min-width:4px;transition:width .3s}.rank-count{font-size:12px;color:var(--text-secondary);flex-shrink:0}.mismatch-section{background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius);padding:16px}.mismatch-hint{font-size:12px;color:#a16207;margin:-4px 0 12px}.mismatch-ok{font-size:13px;color:var(--text-secondary);margin-top:16px}.mismatch-table{font-size:12px;overflow-x:auto}.mismatch-head,.mismatch-row{display:grid;grid-template-columns:90px 56px 40px 1fr 1fr 40px;gap:8px;padding:8px 0;border-bottom:1px solid #FDE68A;align-items:center}.mismatch-head{font-weight:600;color:#92400e}.mismatch-actual{color:#dc2626;font-weight:600}
