.image-selector-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;overflow-y:auto;overflow-x:hidden;padding:20px;display:flex;align-items:flex-start;justify-content:center;min-height:100vh}.image-selector-tabs{display:flex;border-bottom:1px solid #e5e7eb;background:#f9fafb}.tab-button{flex:1;padding:16px 20px;background:transparent;color:#6b7280;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;border:none;border-bottom:3px solid transparent}.tab-button:hover:not(:disabled){background:#f3f4f6;color:#374151}.tab-button.active{background:white;color:#3b82f6;border-bottom-color:#3b82f6}.tab-button:disabled{opacity:.5;cursor:not-allowed}.tab-icon{width:20px;height:20px}.image-selector-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}.image-selector-content{position:relative;background:white;border-radius:16px;width:100%;max-width:1200px;max-height:calc(100vh - 40px);display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);margin:20px 0}.image-selector-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e5e7eb}.image-selector-title{font-size:24px;font-weight:600;color:#111827;display:flex;align-items:center}.image-selector-close{width:36px;height:36px;border-radius:8px;border:none;background:#f3f4f6;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.image-selector-close:hover{background:#e5e7eb;color:#374151}.image-selector-search{padding:20px 24px;border-bottom:1px solid #e5e7eb}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:16px;width:20px;height:20px;color:#9ca3af}.search-input{width:100%;padding:12px 16px 12px 48px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:all .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.search-input:disabled{background:#f9fafb;cursor:not-allowed}.search-loading{position:absolute;right:16px;width:20px;height:20px;color:#3b82f6;animation:spin 1s linear infinite}.suggested-queries{padding:16px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.suggested-queries-label{font-size:14px;color:#6b7280;margin-bottom:12px;display:flex;align-items:center}.suggested-queries-list{display:flex;flex-wrap:wrap;gap:8px}.suggested-query-chip{padding:8px 16px;background:white;border:1px solid #e5e7eb;border-radius:20px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s;touch-action:manipulation;-webkit-user-select:none;-moz-user-select:none;user-select:none}.suggested-query-chip:hover:not(:disabled){background:#3b82f6;color:white;border-color:#3b82f6}.suggested-query-chip:active:not(:disabled){background:#2563eb;transform:scale(.98)}.suggested-query-chip:disabled{opacity:.5;cursor:not-allowed}.current-image-section{padding:16px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.current-image-label{font-size:14px;font-weight:500;color:#6b7280;margin-bottom:12px}.current-image-wrapper{width:200px;height:120px;border-radius:8px;overflow:hidden;border:2px solid #e5e7eb}.current-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.image-grid-container{flex:1;overflow-y:auto;padding:24px}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}.image-grid-item{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s;border:2px solid transparent;background:#f9fafb;touch-action:manipulation;-webkit-user-select:none;-moz-user-select:none;user-select:none}.image-grid-item:hover:not(.disabled){transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.15)}.image-grid-item:active:not(.disabled){transform:translateY(-2px) scale(.98);transition:all .1s}.image-grid-item.selected{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.2)}.image-grid-item.disabled{opacity:.5;cursor:not-allowed}.image-grid-image{width:100%;height:200px;-o-object-fit:cover;object-fit:cover}.image-selected-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(59,130,246,.8);display:flex;align-items:center;justify-content:center}.image-selected-icon{width:48px;height:48px;color:white}.image-info{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(0deg,rgba(0,0,0,.8),transparent)}.image-photographer{font-size:12px;color:white;opacity:.9}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.no-results-icon{width:48px;height:48px;color:#9ca3af;margin-bottom:16px}.no-results p{color:#6b7280;margin-bottom:8px}.no-results-hint{font-size:14px;color:#9ca3af}.load-more-container{display:flex;justify-content:center;padding:24px}.load-more-button{padding:12px 24px;background:#3b82f6;color:white;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;transition:all .2s}.load-more-button:hover:not(:disabled){background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px rgba(59,130,246,.3)}.load-more-button:disabled{background:#9ca3af;cursor:not-allowed}.image-selector-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.error-message{display:flex;align-items:center;gap:12px;padding:16px 24px;background:#fef2f2;color:#991b1b;border-bottom:1px solid #fecaca}.error-icon{width:20px;height:20px;flex-shrink:0}.subscription-notice{margin:16px 24px;padding:16px;background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border:1px solid #c084fc;border-radius:12px}.subscription-notice-content{display:flex;gap:16px}.subscription-notice-icon{width:40px;height:40px;color:#9333ea;flex-shrink:0}.subscription-notice-title{font-size:16px;font-weight:600;color:#581c87;margin-bottom:4px}.subscription-notice-text{font-size:14px;color:#6b21a8;margin-bottom:12px}.subscription-notice-button{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#9333ea;color:white;border-radius:8px;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s}.subscription-notice-button:hover{background:#7e22ce;transform:translateY(-2px);box-shadow:0 4px 12px rgba(147,51,234,.3)}.btn-cancel{padding:10px 20px;background:white;color:#6b7280;border:1px solid #e5e7eb;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#f9fafb;border-color:#d1d5db}.btn-cancel:active{background:#f3f4f6;transform:scale(.98);transition:all .1s}.btn-primary{padding:10px 20px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary.enabled{background:#3b82f6;color:white}.btn-primary.enabled:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px rgba(59,130,246,.3)}.btn-primary.enabled:active{background:#1d4ed8;transform:translateY(-1px) scale(.98);transition:all .1s}.btn-primary.disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.upload-section{padding:24px;flex:1}.upload-area{height:100%;display:flex;flex-direction:column}.upload-input{display:none}.upload-dropzone{flex:1;min-height:300px;border:2px dashed #d1d5db;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;cursor:pointer;transition:all .3s;background:#fafafa}.upload-dropzone:hover:not(.disabled){border-color:#3b82f6;background:#f0f7ff}.upload-dropzone.disabled{opacity:.5;cursor:not-allowed;border-color:#e5e7eb}.upload-icon{width:48px;height:48px;color:#9ca3af;margin-bottom:16px}.upload-title{font-size:20px;font-weight:600;color:#374151;margin-bottom:8px}.upload-description{font-size:16px;color:#6b7280;margin-bottom:12px}.upload-requirements{font-size:14px;color:#9ca3af}.upload-preview{flex:1;display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:white}.upload-preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.upload-preview-title{font-size:18px;font-weight:600;color:#374151}.upload-clear-button{width:32px;height:32px;border-radius:6px;border:none;background:#f3f4f6;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.upload-clear-button:hover:not(:disabled){background:#e5e7eb;color:#374151}.upload-preview-image{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;background:#f9fafb}.preview-image{max-width:100%;max-height:300px;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.upload-preview-info{padding:16px;background:white;border-top:1px solid #e5e7eb}.upload-filename{font-size:16px;font-weight:500;color:#374151;margin-bottom:4px}.upload-filesize{font-size:14px;color:#6b7280}.upload-progress{padding:16px;background:#f9fafb;border-top:1px solid #e5e7eb}.upload-progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:8px}.upload-progress-fill{height:100%;background:#3b82f6;transition:width .3s ease}.upload-progress-text{font-size:14px;color:#6b7280;text-align:center}.regenerate-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;overflow-y:auto;overflow-x:hidden;padding:20px;display:flex;align-items:flex-start;justify-content:center;min-height:100vh}.regenerate-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}.regenerate-modal-content{position:relative;background:white;border-radius:16px;width:100%;max-width:600px;max-height:calc(100vh - 40px);display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);overflow:hidden;margin:20px 0}.regenerate-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e5e7eb}.regenerate-modal-title{font-size:24px;font-weight:600;color:#111827}.regenerate-modal-close{width:36px;height:36px;border-radius:8px;border:none;background:#f3f4f6;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.regenerate-modal-close:hover:not(:disabled){background:#e5e7eb;color:#374151}.regenerate-modal-close:disabled{opacity:.5;cursor:not-allowed}.regenerate-form{padding:24px;flex:1;overflow-y:auto}.regenerate-warning{padding:16px;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-bottom:24px}.regenerate-warning p{font-size:14px;color:#92400e;margin:0;line-height:1.5}.regenerate-warning strong{font-weight:600}.form-select{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;color:#374151;background:white;transition:all .2s}.form-select:focus{outline:none;border-color:#9333ea;box-shadow:0 0 0 3px rgba(147,51,234,.1)}.form-select.disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed;opacity:.6}@media (max-width:768px){.image-selector-modal{padding:0;align-items:flex-start}.image-selector-content{max-height:100vh;height:100vh;border-radius:0;margin:0;overflow:hidden}.image-selector-header{padding:16px 20px;flex-shrink:0}.image-selector-title{font-size:20px}.image-selector-tabs{flex-shrink:0}.tab-button{padding:12px 16px;font-size:14px;min-height:48px}.image-selector-search{padding:16px 20px;flex-shrink:0}.search-input{min-height:48px;font-size:16px}.suggested-queries{padding:12px 20px;flex-shrink:0}.suggested-queries-list{display:flex;flex-wrap:wrap;gap:8px}.suggested-query-chip{padding:10px 16px;min-height:40px;font-size:14px;flex-shrink:0}.current-image-section{padding:12px 20px;flex-shrink:0}.image-grid-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 20px;min-height:0}.image-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:20px}.image-grid-item{border-radius:8px;min-height:140px}.image-grid-image{height:140px}.load-more-container{padding:16px 0;flex-shrink:0}.load-more-button{min-height:48px;padding:12px 24px;font-size:16px}.image-selector-footer{padding:16px 20px;flex-shrink:0;position:sticky;bottom:0;background:#f9fafb;border-top:1px solid #e5e7eb;box-shadow:0 -2px 8px rgba(0,0,0,.1)}.btn-cancel,.btn-primary{min-height:48px;padding:12px 20px;font-size:16px;flex:1}.upload-section{padding:16px 20px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.upload-dropzone{min-height:200px;padding:20px;border-width:2px}.upload-icon{width:36px;height:36px}.upload-title{font-size:18px}.upload-description{font-size:14px}.upload-requirements{font-size:12px}.error-message{padding:12px 20px;font-size:14px;flex-shrink:0}.subscription-notice{margin:12px 20px;padding:12px}.subscription-notice-content{flex-direction:column;text-align:center;gap:12px}.subscription-notice-icon{align-self:center}.subscription-notice-button{align-self:center;min-height:44px;padding:12px 20px}.no-results{padding:40px 20px}.no-results-icon{width:40px;height:40px}.regenerate-modal{padding:0;align-items:flex-start}.regenerate-modal-content{max-height:100vh;height:100vh;border-radius:0;margin:0}.regenerate-form{overflow-y:auto;-webkit-overflow-scrolling:touch}}@media (max-width:480px){.image-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.image-grid-item{min-height:120px}.image-grid-image{height:120px}.image-selector-header{padding:12px 16px}.current-image-section,.image-grid-container,.image-selector-search,.suggested-queries,.upload-section{padding-left:16px;padding-right:16px}.image-selector-footer{padding:12px 16px}}