.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:44px;padding:var(--space-3) var(--space-5);font-size:var(--text-body);font-weight:600;border-radius:var(--radius-full);transition:transform var(--duration-fast) var(--ease-default),opacity var(--duration-fast) var(--ease-default)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--system-blue);color:#fff}.btn-primary:hover:not(:disabled){opacity:.9}.btn-secondary{background:var(--bg-tertiary);color:var(--label-primary);border:1px solid var(--separator)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary)}.btn-ghost{background:transparent;color:var(--system-blue)}.btn-ghost:hover:not(:disabled){background:#007aff1a}.btn-icon{font-size:1.1em}.option-group{display:flex;flex-wrap:wrap;gap:var(--space-2)}.option-btn{min-width:56px;padding:var(--space-2) var(--space-4);font-size:var(--text-footnote);font-weight:500;color:var(--label-primary);background:var(--bg-tertiary);border:1px solid var(--separator);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-default)}.option-btn:hover{background:var(--bg-secondary)}.option-btn.active{background:var(--system-blue);color:#fff;border-color:var(--system-blue)}.option-btn:active{transform:scale(.97)}.aspect-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-2);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md)}.aspect-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-2);font-size:var(--text-caption);color:var(--label-secondary);background:transparent;border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease-default)}.aspect-btn:hover{background:var(--bg-tertiary)}.aspect-btn.active{background:var(--bg-tertiary);color:var(--label-primary);box-shadow:0 2px 8px #00000014}.aspect-btn:active{transform:scale(.95)}.aspect-icon{border:1px solid var(--system-gray3);border-radius:2px;background:var(--bg-tertiary)}.aspect-square{width:16px;height:16px}.aspect-portrait{width:12px;height:18px}.aspect-landscape{width:20px;height:12px}.upload-zone{border:2px dashed var(--separator);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;transition:all var(--duration-fast) var(--ease-default);background:var(--bg-tertiary)}.upload-zone:hover,.upload-zone.dragover{border-color:var(--system-blue);background:#007aff0d}.upload-trigger{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4) 0;color:var(--label-tertiary);font-size:var(--text-footnote);cursor:pointer}.upload-icon{font-size:32px;opacity:.5}.ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:var(--space-2);margin-top:var(--space-3)}.ref-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--separator);cursor:zoom-in}.ref-thumb img{width:100%;height:100%;object-fit:cover;transition:opacity var(--duration-fast)}.ref-thumb:hover img{opacity:.8}.ref-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#0009;color:#fff;border-radius:50%;font-size:12px;display:flex;align-items:center;justify-content:center}.ref-remove:hover{background:var(--system-red)}.accordion{background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--separator)}.accordion-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);font-size:var(--text-footnote);font-weight:500;cursor:pointer;transition:background var(--duration-fast);gap:var(--space-3)}.accordion-title{flex:1;min-width:0}.accordion-right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.accordion-actions{display:flex;align-items:center;flex-shrink:0}.accordion-header:hover{background:var(--system-gray5)}.accordion-arrow{font-size:10px;color:var(--label-tertiary);transition:transform var(--duration-fast) var(--ease-default)}.accordion.open .accordion-arrow{transform:rotate(180deg)}.accordion-content{display:none;padding:var(--space-4)}.accordion.open .accordion-content{display:block}.lightbox{position:fixed;inset:0;background:#000000f2;z-index:1000;display:flex;justify-content:center;align-items:center;opacity:0;visibility:hidden;transition:opacity var(--duration-normal) var(--ease-default),visibility var(--duration-normal)}.lightbox.open{opacity:1;visibility:visible}.lightbox-controls{position:absolute;top:var(--space-5);right:var(--space-5);display:flex;gap:var(--space-3);z-index:1001}.lightbox-btn{padding:var(--space-2) var(--space-4);background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);font-size:var(--text-footnote);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lightbox-btn:hover{background:#fff3}.lightbox-wrapper{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.lightbox-img{max-width:90vw;max-height:90vh;box-shadow:0 0 50px #00000080;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform .05s linear}.lightbox-img.grabbing{cursor:grabbing}.lightbox-hint{position:absolute;bottom:var(--space-8);left:50%;transform:translate(-50%);color:#ffffff80;font-size:var(--text-caption)}.toast{position:fixed;bottom:var(--space-8);left:50%;transform:translate(-50%) translateY(20px);background:var(--bg-tertiary);border:1px solid var(--separator);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-size:var(--text-footnote);color:var(--label-primary);box-shadow:0 8px 32px #0000001f;display:flex;align-items:center;gap:var(--space-2);opacity:0;pointer-events:none;transition:all var(--duration-normal) var(--ease-spring);z-index:2000}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast-icon{width:8px;height:8px;border-radius:50%}.toast.success .toast-icon{background:var(--system-green)}.toast.error .toast-icon{background:var(--system-red)}@media(prefers-color-scheme:dark){.toast{box-shadow:0 8px 32px #0006}}:root{--font-system: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", SFMono-Regular, Menlo, Monaco, monospace;--text-caption: 12px;--text-footnote: 13px;--text-body: 17px;--text-headline: 17px;--text-title3: 20px;--text-title2: 22px;--text-title1: 28px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--ease-default: cubic-bezier(.25, .1, .25, 1);--ease-spring: cubic-bezier(.175, .885, .32, 1.275);--duration-fast: .2s;--duration-normal: .3s;--system-blue: #007AFF;--system-green: #34C759;--system-red: #FF3B30;--system-gray: #8E8E93;--system-gray2: #AEAEB2;--system-gray3: #C7C7CC;--system-gray4: #D1D1D6;--system-gray5: #E5E5EA;--system-gray6: #F2F2F7;--label-primary: #000000;--label-secondary: rgba(60, 60, 67, .6);--label-tertiary: rgba(60, 60, 67, .3);--bg-primary: #FFFFFF;--bg-secondary: #F2F2F7;--bg-tertiary: #FFFFFF;--separator: rgba(60, 60, 67, .29)}@media(prefers-color-scheme:dark){:root{--system-blue: #0A84FF;--system-green: #30D158;--system-red: #FF453A;--system-gray: #8E8E93;--system-gray2: #636366;--system-gray3: #48484A;--system-gray4: #3A3A3C;--system-gray5: #2C2C2E;--system-gray6: #1C1C1E;--label-primary: #FFFFFF;--label-secondary: rgba(235, 235, 245, .6);--label-tertiary: rgba(235, 235, 245, .3);--bg-primary: #000000;--bg-secondary: #1C1C1E;--bg-tertiary: #2C2C2E;--separator: rgba(84, 84, 88, .6)}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font-system);font-size:var(--text-body);color:var(--label-primary);background:var(--bg-secondary);line-height:1.4}@media(max-width:1100px){html,body,#root{height:auto}body{overflow-y:auto}}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea{font-family:inherit;font-size:var(--text-body);color:var(--label-primary);background:var(--bg-secondary);border:none;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);width:100%;outline:none;transition:box-shadow var(--duration-fast) var(--ease-default)}input:focus,textarea:focus{box-shadow:0 0 0 4px #007aff4d}input::placeholder,textarea::placeholder{color:var(--label-tertiary)}textarea{resize:vertical;min-height:120px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--system-gray3);border-radius:3px}.app{display:flex;width:100%;height:100vh;overflow:hidden}@media(max-width:900px){.app{flex-direction:column;height:auto;overflow:visible}}.preview-panel{flex:1;display:flex;flex-direction:column;padding:var(--space-6);gap:var(--space-5);min-width:0;min-height:0;overflow:hidden}.canvas-wrapper{flex:1;background:var(--bg-tertiary);border-radius:var(--radius-xl);border:1px solid var(--separator);display:flex;justify-content:center;align-items:center;overflow:hidden;min-height:0;box-shadow:0 4px 16px #0000000a}.main-image{max-width:100%;max-height:100%;object-fit:contain;opacity:0;transition:opacity var(--duration-normal) var(--ease-default);cursor:zoom-in}.main-image.loaded{opacity:1}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);color:var(--label-tertiary)}.empty-icon{font-size:48px;opacity:.4}.toolbar{display:flex;gap:var(--space-3);justify-content:center}.history-bar{display:flex;gap:var(--space-3);overflow-x:auto;padding-bottom:var(--space-2)}.resizer{flex:0 0 10px;width:10px;position:relative;cursor:col-resize;touch-action:none}.resizer:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;background:var(--separator);transform:translate(-.5px)}.resizer:hover:before,.resizer:focus-visible:before{width:2px;background:var(--system-blue);transform:translate(-1px)}.resizer:focus-visible{outline:none}.history-thumb{width:70px;height:70px;border-radius:var(--radius-sm);border:2px solid transparent;overflow:hidden;cursor:pointer;flex-shrink:0;transition:all var(--duration-fast) var(--ease-spring);background:var(--bg-tertiary);box-shadow:0 2px 8px #0000000f}.history-thumb img{width:100%;height:100%;object-fit:cover}.history-thumb.active{border-color:var(--system-blue);transform:translateY(-2px)}.control-panel{width:420px;display:flex;flex-direction:column;padding:var(--space-6);gap:var(--space-5);overflow:hidden;flex-shrink:0;min-height:0}.control-panel-header{flex-shrink:0}.header-action-btn.btn{min-height:32px;padding:6px 12px;font-size:var(--text-caption);font-weight:600;background:#7676801f;border-color:#3c3c432e;box-shadow:0 2px 10px #0000000f;white-space:nowrap}.header-action-btn.btn:focus-visible{box-shadow:0 0 0 4px #007aff40,0 2px 10px #0000000f;outline:none}.header-action-btn.btn:active:not(:disabled){transform:scale(.98)}.header-action-btn.btn:hover:not(:disabled){background:#7676802e}.usage-query-icon{width:14px;height:14px;flex:0 0 auto}.control-panel-body{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-5);padding-right:2px}@media(max-width:900px){.control-panel{width:100%;border-top:1px solid var(--separator);overflow:visible}.preview-panel{border-right:none}.resizer{display:none}.control-panel-body{flex:none;min-height:auto;overflow:visible;padding-right:0}}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-footnote);font-weight:500;color:var(--label-secondary)}.form-hint{font-size:var(--text-caption);color:var(--label-tertiary)}.input-wrapper{position:relative;padding:4px}.clear-btn{position:absolute;top:calc(var(--space-2) + 4px);right:calc(var(--space-2) + 4px);width:24px;height:24px;background:var(--system-gray5);border-radius:50%;font-size:12px;color:var(--label-tertiary);display:flex;align-items:center;justify-content:center}.clear-btn:hover{background:var(--system-red);color:#fff}.generate-btn{width:100%;min-height:50px;background:var(--system-blue);color:#fff;font-size:var(--text-body);font-weight:600;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:var(--space-2);box-shadow:0 4px 12px #007aff4d;transition:all var(--duration-fast) var(--ease-default)}.generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #007aff66}.generate-btn:active:not(:disabled){transform:translateY(1px)}.generate-btn:disabled{background:var(--system-gray3);box-shadow:none}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.meta-info{background:var(--bg-secondary);padding:var(--space-3);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-caption);color:var(--label-secondary);white-space:pre-wrap;overflow-x:auto}.log-box{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:var(--space-3);max-height:150px;overflow-y:auto;font-family:var(--font-mono);font-size:var(--text-caption);color:var(--label-secondary)}.log-entry{margin-bottom:var(--space-1)}.header-actions{display:flex;align-items:center;gap:var(--space-2)}.help-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;justify-content:center;align-items:center;padding:var(--space-6);z-index:50}.help-modal{width:min(840px,100%);max-height:min(86vh,900px);background:var(--bg-tertiary);border-radius:var(--radius-xl);border:1px solid var(--separator);overflow:hidden;box-shadow:0 16px 40px #0000003d;display:flex;flex-direction:column}.help-modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-secondary);border-bottom:1px solid var(--separator)}.help-modal-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.help-modal-title{font-size:var(--text-headline);font-weight:700}.help-modal-body{padding:var(--space-5);overflow:auto;color:var(--label-secondary)}.help-modal-body p{color:var(--label-secondary);margin-bottom:var(--space-4)}.help-modal-body h3{color:var(--label-primary);font-size:var(--text-footnote);font-weight:800;margin-top:var(--space-5);margin-bottom:var(--space-2)}.help-modal-body ul{padding-left:18px;margin-bottom:var(--space-4)}.help-modal-body li{margin:8px 0}.help-modal-body code{font-family:var(--font-mono);font-size:.95em;padding:2px 6px;border-radius:8px;background:#7676801f;color:var(--label-primary)}.help-footer-hint{font-size:var(--text-footnote);color:var(--label-tertiary);margin-top:var(--space-5)}@media(max-width:900px){.help-modal-overlay{padding:var(--space-4);align-items:stretch}.help-modal{max-height:92vh}.help-modal-body{padding:var(--space-4)}}
