.prompt-templates{margin-bottom:16px}.template-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.template-select-wrap{position:relative;flex:1;min-width:140px}.template-select-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:6px;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.template-select-btn:hover{border-color:var(--accent-primary);background:var(--bg-card-hover)}.template-select-btn .open{transform:rotate(180deg)}.template-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;max-height:200px;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:0 8px 24px #00000040;z-index:100;-webkit-backdrop-filter:none;backdrop-filter:none}.template-dropdown-empty{padding:12px;font-size:12px;color:var(--text-muted);text-align:center}.template-option{display:block;width:100%;padding:10px 12px;text-align:left;background:none;border:none;color:var(--text-primary);font-size:13px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.template-option:hover{background:var(--bg-card-hover)}.template-option.active{background:#6366f11f;color:var(--accent-primary)}.template-actions{display:flex;gap:6px}.template-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.template-btn:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f114}.template-btn:disabled{opacity:.5;cursor:not-allowed}.template-btn.delete:hover:not(:disabled){border-color:var(--danger);color:var(--danger);background:#ef444414}.template-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.template-modal{width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 20px 60px #0006;-webkit-backdrop-filter:none;backdrop-filter:none}.template-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.template-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.template-modal-close{padding:4px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:6px}.template-modal-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.template-modal-body{flex:1;overflow-y:auto;padding:20px}.template-form-row{margin-bottom:16px}.template-form-row:last-child{margin-bottom:0}.template-form-row label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.template-form-row input,.template-form-row textarea{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:var(--font-sans);box-sizing:border-box}.template-form-row textarea{resize:vertical;min-height:80px}.template-form-row input:focus,.template-form-row textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.template-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-color)}.template-modal-cancel{padding:8px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;cursor:pointer;font-family:var(--font-sans)}.template-modal-cancel:hover{background:var(--bg-card-hover);color:var(--text-primary)}.template-modal-save{padding:8px 20px;background:var(--accent-gradient);border:none;border-radius:var(--radius-sm);color:#fff;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans)}.template-modal-save:hover:not(:disabled){opacity:.9}.template-modal-save:disabled{opacity:.5;cursor:not-allowed}.image-page{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.image-layout{flex:1;display:grid;grid-template-columns:1fr 1fr;overflow:hidden}.image-panel-left{display:flex;flex-direction:column;border-right:1px solid var(--border-color);overflow:hidden}.panel-scroll{flex:1;overflow-y:auto;padding:24px 24px 12px}.panel-scroll::-webkit-scrollbar{width:3px}.panel-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.panel-section{margin-bottom:16px}.panel-label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:7px}.panel-sublabel{font-size:11px;color:var(--text-muted);line-height:1.45;margin:-2px 0 10px}.required{color:var(--accent-primary)}.panel-textarea{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:var(--font-sans);outline:none;resize:vertical;line-height:1.6;transition:var(--transition);box-sizing:border-box}.panel-textarea.small{resize:none}.panel-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.panel-textarea::placeholder{color:var(--text-muted)}.image-desc-section .image-prompt-wrap{position:relative;width:100%}.image-prompt-textarea{min-height:120px;padding-bottom:38px;padding-right:10px}.image-model-seg{position:absolute;right:8px;bottom:8px;display:flex;flex-wrap:wrap;justify-content:flex-end;gap:4px;max-width:calc(100% - 16px);z-index:1}.image-model-seg-btn{font-size:10px;padding:4px 7px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;font-family:var(--font-sans);line-height:1.2;transition:var(--transition);white-space:nowrap}.image-model-seg-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.image-model-seg-btn.active{border-color:var(--accent-primary);background:#6366f11f;color:var(--accent-primary)}.ref-upload-wrap{border:2px dashed var(--border-color);border-radius:var(--radius-sm);padding:12px;text-align:center;cursor:default;transition:var(--transition);min-height:72px;display:block;outline:none}.ref-upload-wrap:hover,.ref-upload-wrap.drag{border-color:var(--accent-primary);background:#6366f10a}.ref-upload-wrap.has-thumbs{padding:10px}.ref-dropzone-empty{width:100%;min-height:88px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text-muted);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-sans);transition:var(--transition)}.ref-dropzone-empty:hover{color:var(--text-secondary)}.ref-dropzone-title{font-size:12px}.ref-dropzone-sub{font-size:11px;line-height:1.4;max-width:100%;opacity:.9;padding:0 4px}.ref-thumbs-block{text-align:left}.ref-thumbs{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}.ref-thumb{position:relative;width:72px;flex-shrink:0;border-radius:8px;overflow:visible;border:1px solid var(--border-color);background:var(--bg-input)}.ref-thumb-crop{width:72px;height:72px;border-radius:7px;overflow:hidden;background:var(--bg-card)}.ref-thumb-crop img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.ref-thumb-remove{position:absolute;top:-5px;right:-5px;width:20px;height:20px;border-radius:50%;background:#000000b3;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;z-index:1;transition:var(--transition)}.ref-thumb-remove:hover{background:var(--danger)}.ref-add-tile{width:72px;height:72px;flex-shrink:0;border-radius:8px;border:2px dashed var(--border-color);background:var(--bg-input);color:var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:10px;cursor:pointer;font-family:var(--font-sans);transition:var(--transition)}.ref-add-tile:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f10f}.ref-thumbs-hint,.ref-panel-hint{margin:8px 0 0;font-size:11px;line-height:1.4;color:var(--text-muted)}.ref-panel-hint{color:var(--danger)}.panel-row{display:flex;gap:12px;margin-bottom:16px}.flex-1{flex:1}.ratio-mode-bar{display:flex;gap:6px;margin-bottom:10px}.ratio-mode-btn{flex:1;padding:6px 10px;font-size:12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;font-family:var(--font-sans);transition:var(--transition)}.ratio-mode-btn:hover{color:var(--text-primary);border-color:var(--border-hover)}.ratio-mode-btn.active{background:#6366f11f;border-color:#6366f173;color:var(--accent-primary)}.custom-canvas-block{margin-top:2px}.custom-canvas-hint{font-size:11px;color:var(--text-muted);line-height:1.45;margin:0 0 10px}.custom-canvas-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:8px 10px}.custom-canvas-field{display:flex;flex-direction:column;align-items:flex-start;gap:4px;min-width:0}.custom-canvas-label-text{font-size:11px;color:var(--text-secondary)}.custom-canvas-input{width:96px;padding:6px 8px;font-size:13px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-family:var(--font-sans);box-sizing:border-box}.custom-canvas-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.custom-canvas-x{color:var(--text-muted);font-size:14px;padding-bottom:6px}.custom-canvas-px{font-size:12px;color:var(--text-muted);padding-bottom:6px}.ratio-grid{display:flex;flex-wrap:wrap;gap:5px}.ratio-btn{padding:5px 10px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.ratio-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.ratio-btn.active{background:#6366f126;border-color:#6366f166;color:var(--accent-primary)}.size-grid{display:flex;gap:8px}.size-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 6px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans);text-align:center}.size-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.size-btn.active{background:#6366f126;border-color:#6366f166;color:var(--accent-primary)}.size-label{font-weight:600;font-size:13px}.size-desc{font-size:10px;color:var(--text-muted)}.size-btn.active .size-desc{color:#6366f1cc}.panel-footer{padding:14px 20px;border-top:1px solid var(--border-color);flex-shrink:0}.generate-btn{width:100%;padding:12px;background:var(--accent-gradient);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition);font-family:var(--font-sans);box-shadow:0 2px 10px var(--accent-glow)}.generate-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.generate-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-spinner{width:15px;height:15px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.image-panel-right{display:flex;flex-direction:column;overflow:hidden;min-height:0;padding:12px 14px 14px;gap:8px}.result-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-muted);gap:12px}.result-empty-icon{width:72px;height:72px;border-radius:20px;background:var(--bg-card);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center}.result-empty h3{font-size:16px;font-weight:600;color:var(--text-secondary)}.result-empty p{font-size:13px;color:var(--text-muted)}.result-bar{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.result-count{font-size:13px;color:var(--text-secondary)}.result-clear-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-muted);font-size:12px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.result-clear-btn:hover{color:var(--danger);border-color:var(--danger)}.image-restore-hint{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:12px;color:var(--text-secondary);background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:10px}.image-restore-hint .mini-spinner{width:14px;height:14px;border:2px solid rgba(99,102,241,.25);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .85s linear infinite;flex-shrink:0}.gen-error-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:10px;font-size:13px;color:var(--danger);flex-shrink:0}.gen-error-card button{background:transparent;border:none;color:var(--danger);font-size:16px;cursor:pointer;line-height:1;flex-shrink:0}.generating-card{display:flex;align-items:center;gap:14px;padding:14px 18px;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:12px;flex-shrink:0}.gen-spinner{width:28px;height:28px;border:2.5px solid rgba(99,102,241,.2);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .9s linear infinite;flex-shrink:0}.gen-title{font-size:13px;font-weight:500;color:var(--accent-primary)}.gen-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.image-grid{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-content:start;padding-right:2px}.image-grid::-webkit-scrollbar{width:6px}.image-grid::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.image-card{min-width:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:border-color .2s,box-shadow .2s;display:flex;flex-direction:column}.image-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.image-card-img{position:relative;cursor:zoom-in;width:100%;height:152px;flex-shrink:0;background:var(--bg-tertiary);overflow:hidden;border-radius:7px 7px 0 0}.image-card-img.no-src{cursor:default}.image-card-img img{position:absolute;z-index:0;left:0;top:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .3s ease;pointer-events:none}.image-thumb-skeleton{position:absolute;inset:0;background:linear-gradient(105deg,var(--bg-tertiary) 0%,var(--bg-card-hover) 42%,var(--bg-tertiary) 84%);background-size:200% 100%;animation:image-skel-shimmer 1.1s ease-in-out infinite}@keyframes image-skel-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.image-thumb-missing{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-muted);background:var(--bg-tertiary);font-size:10px;text-align:center;padding:6px;line-height:1.3}.image-card:hover .image-card-img img{transform:scale(1.03)}.image-card-overlay{z-index:1;position:absolute;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;pointer-events:none}.image-card:hover .image-card-overlay{opacity:1;visibility:visible}.image-card-toolbar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:4px;padding:4px 6px;background:var(--bg-card);border-top:1px solid var(--border-color)}.image-card-toolbar .img-tool-btn{flex:1;min-width:0;display:inline-flex;align-items:center;justify-content:center;padding:4px 2px;background:transparent;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.image-card-toolbar .img-tool-btn:hover:not(:disabled){background:var(--bg-card-hover);color:var(--accent-primary)}.image-card-toolbar .img-tool-btn.regen{color:var(--accent-primary)}.image-card-toolbar .img-tool-btn.regen:hover:not(:disabled){background:#6366f11a}.image-card-toolbar .img-tool-btn.danger:hover:not(:disabled){background:#ef44441a;color:var(--danger)}.image-card-toolbar .img-tool-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.lightbox{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}.lightbox-inner{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;gap:12px}.lightbox-inner img{max-width:100%;max-height:75vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px #0009}.lightbox-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 4px}.lightbox-bar span{font-size:13px;color:#ffffffb3;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lightbox-actions{display:flex;gap:8px;flex-shrink:0}.lb-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-size:13px;cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.lb-btn:hover{background:#fff3}.lb-btn.close:hover{background:#ef44444d;border-color:#ef444466}
