:root{--background-primary: #111827;--surface-primary: #1F2937;--surface-secondary: #374151;--surface-hover: #4B5563;--primary-accent: #3B82F6;--primary-accent-hover: #2563EB;--text-primary: #F9FAFB;--text-secondary: #9CA3AF;--border-primary: #374151;--error-color: #EF4444;--success-color: #22C55E;--focus-ring-color: rgba(59, 130, 246, .4)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background-color:var(--background-primary);color:var(--text-primary);line-height:1.6;overflow:hidden}#root{width:100%;height:100vh}.container{height:100vh;width:100%;background-color:var(--background-primary);display:flex;transition:padding-bottom .3s ease-in-out}.landing-page-container{width:100%;height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;background:radial-gradient(ellipse at bottom,#1b2735,#090a0f);padding:2rem;overflow:auto}.landing-content{max-width:800px;animation:fadeIn 1s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing-header{margin-bottom:2rem}.landing-header h1{font-size:3rem;font-weight:700;letter-spacing:-1px;margin-bottom:.5rem}.landing-header .subtitle{font-size:1.1rem;color:var(--text-secondary)}.landing-hero p{font-size:1.25rem;color:var(--text-primary);margin-bottom:2.5rem;max-width:600px;margin-left:auto;margin-right:auto}.landing-cta-btn{display:inline-flex;align-items:center;justify-content:center;padding:.9rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;background:var(--primary-accent);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #3b82f633;margin-bottom:4rem}.landing-cta-btn:hover{background:var(--primary-accent-hover);transform:translateY(-3px);box-shadow:0 6px 25px #3b82f64d}.landing-features{display:flex;justify-content:center;gap:2rem;max-width:900px;margin:0 auto;flex-wrap:wrap}.feature-item{background-color:#1f29374d;border:1px solid var(--border-primary);padding:1.5rem;border-radius:8px;width:240px;transition:all .3s ease}.feature-item:hover{transform:translateY(-5px);border-color:var(--primary-accent)}.feature-icon{font-size:2rem;color:var(--primary-accent);margin-bottom:1rem}.feature-item h3{font-size:1.1rem;margin-bottom:.5rem}.feature-item p{font-size:.9rem;color:var(--text-secondary)}.landing-footer{position:absolute;bottom:1.5rem;font-size:.85rem;color:var(--text-secondary)}.controls-panel{width:340px;flex-shrink:0;height:100%;background-color:var(--surface-primary);padding:1.5rem;display:flex;flex-direction:column;border-right:1px solid var(--border-primary)}.controls-panel header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.header-main-content{flex-grow:1}.header-actions{display:flex;gap:.5rem;flex-shrink:0}.controls-panel h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.controls-panel p.subtitle{color:var(--text-secondary);font-size:.9rem}.form-controls{flex-grow:1;overflow-y:auto;overflow-x:hidden;min-height:0;padding-bottom:1rem}.input-group{margin-bottom:1.5rem}.input-group label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.5rem;color:var(--text-secondary)}.input-group textarea,.input-group input[type=text],.input-group input[type=number],.input-group select{width:100%;padding:.75rem;background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:1rem;font-family:Inter,sans-serif;transition:border-color .2s ease,box-shadow .2s ease}.user-info{margin-bottom:2rem;position:relative}.user-info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.user-info label{font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:0}.api-key-status{display:flex;align-items:center;gap:.4rem;background-color:#22c55e1a;border:1px solid rgba(34,197,94,.5);color:var(--success-color);padding:.2rem .6rem;font-size:.75rem;font-weight:500;border-radius:1rem;cursor:pointer;transition:all .2s ease}.api-key-status:hover{background-color:#22c55e33;border-color:var(--success-color)}.api-key-dot{width:8px;height:8px;border-radius:50%;background-color:var(--success-color)}.user-display{display:flex;align-items:center;gap:.75rem;background-color:var(--background-primary);padding:.5rem;border-radius:8px;border:1px solid var(--border-primary);cursor:pointer;transition:background-color .2s ease}.user-display:hover{background-color:var(--surface-secondary)}.user-name-credits{display:flex;flex-direction:column}.user-credits{font-size:.8rem;color:var(--text-secondary)}.user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--border-primary)}.user-name{font-weight:500;color:var(--text-primary)}.user-menu{position:absolute;top:100%;right:0;background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 5px 15px #0000004d;z-index:10;width:180px;margin-top:.5rem;overflow:hidden}.user-menu button{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;color:var(--text-primary);text-align:left;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.user-menu button:hover{background-color:var(--primary-accent)}.input-group input[type=number]{padding-right:5rem}.input-group input[type=number]::-webkit-outer-spin-button,.input-group input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.input-group input[type=number]{-moz-appearance:textfield}.visual-type-selector-wrapper{display:flex;align-items:center;gap:.5rem}.visual-type-selector-wrapper select{flex-grow:1}.edit-visual-types-btn{padding:.6rem 1rem;background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:8px;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s ease}.edit-visual-types-btn:hover{background-color:var(--surface-hover)}.visual-type-selector-wrapper select:disabled,.edit-visual-types-btn:disabled{opacity:.5;cursor:not-allowed;background-color:var(--surface-secondary)}.inpaint-side-panel .input-group select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--surface-secondary)}.input-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239CA3AF'%3E%3Cpath d='M6 9L.5 3h11z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px}.input-group textarea{resize:vertical}.input-group textarea:focus,.input-group input[type=text]:focus,.input-group input[type=number]:focus,.input-group select:focus{outline:none;border-color:var(--primary-accent);box-shadow:0 0 0 3px var(--focus-ring-color)}.workflow-description{font-size:.8rem;color:var(--text-secondary);margin-top:.75rem;padding:.75rem;background-color:var(--background-primary);border-radius:6px;border:1px solid var(--border-primary);line-height:1.4}.metadata-panel{background-color:var(--background-primary);border:1px solid var(--border-primary);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.metadata-panel h3{font-size:1rem;font-weight:600;margin-bottom:1rem;border-bottom:1px solid var(--border-primary);padding-bottom:.5rem}.metadata-item{font-size:.85rem;margin-bottom:.75rem;color:var(--text-secondary);display:flex;align-items:center}.metadata-item span{font-weight:500;color:var(--text-primary);margin-right:.5rem;flex-shrink:0}.metadata-item p{display:inline;color:var(--text-secondary);word-break:break-word}.metadata-item .copy-btn{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-secondary);padding:.1rem .5rem;font-size:.7rem;font-weight:500;border-radius:4px;cursor:pointer;margin-left:.75rem;transition:all .2s ease}.metadata-item .copy-btn:hover{background-color:var(--primary-accent);color:#fff;border-color:var(--primary-accent)}.metadata-sources{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem;align-items:center}.metadata-sources button{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-secondary);padding:.2rem .6rem;font-size:.75rem;border-radius:4px;cursor:pointer;transition:all .2s ease}.metadata-sources button:hover{background-color:var(--primary-accent);border-color:var(--primary-accent);color:#fff}.metadata-sources .breadcrumb-separator{color:var(--text-secondary);font-weight:700}.suggestion-groups{display:flex;flex-direction:column;gap:.5rem}.suggestion-accordion{border-bottom:1px solid var(--border-primary)}.suggestion-accordion:last-child{border-bottom:none}.suggestion-accordion summary{cursor:pointer;padding:.75rem .25rem;font-size:.9rem;font-weight:500;list-style:none;display:flex;justify-content:space-between;align-items:center}.suggestion-accordion summary::-webkit-details-marker{display:none}.suggestion-accordion summary:after{content:"▸";transition:transform .2s ease}.suggestion-accordion[open]>summary:after{transform:rotate(90deg)}.parent-accordion>summary{font-size:1rem;font-weight:600;padding:.9rem .25rem}.nested-controls{padding:.5rem 0 .5rem .75rem;border-top:1px solid var(--border-primary);margin-top:.5rem;display:flex;flex-direction:column;gap:1rem}.nested-controls .suggestion-accordion{border-bottom:none}.nested-controls .suggestion-groups{margin-bottom:0}.nested-controls-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.core-concept-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.core-concept-header label{margin-bottom:0}.inspire-btn{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-secondary);border-radius:6px;cursor:pointer;padding:.3rem .6rem;display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;transition:all .2s ease}.inspire-btn:hover{background-color:var(--primary-accent);border-color:var(--primary-accent);color:#fff}.inspire-btn svg{width:12px;height:12px}.suggestion-chips{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem 0 1rem}.suggestion-chip{background-color:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-secondary);padding:.25rem .75rem;font-size:.8rem;border-radius:1rem;cursor:pointer;transition:all .2s ease}.suggestion-chip:hover{background-color:var(--surface-hover);color:var(--text-primary);border-color:#555}.image-input-container{padding-top:.5rem;transition:box-shadow .3s ease-out;border-radius:8px}@keyframes flash-animation{0%{box-shadow:0 0 #3b82f600}50%{box-shadow:0 0 0 4px var(--focus-ring-color)}to{box-shadow:0 0 #3b82f600}}.image-input-container.pasted-flash{animation:flash-animation 1.5s ease-out}.image-upload-placeholder{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;height:150px;border:2px dashed var(--border-primary);border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.image-upload-placeholder:hover{border-color:var(--primary-accent);color:var(--primary-accent);background-color:#3b82f60d}.image-upload-placeholder span{font-size:2.5rem;line-height:1}.image-upload-placeholder p{margin-top:.5rem;font-size:.9rem}.image-preview-container{position:relative;width:100%;padding-bottom:100%;background-color:var(--background-primary);border-radius:8px}.image-preview{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain}.image-input-tools{position:absolute;bottom:.75rem;right:.75rem}.sketch-canvas-container{padding-top:.5rem;display:flex;flex-direction:column;gap:1rem}.sketch-input-note{font-size:.8rem;color:var(--text-secondary);padding:0 .25rem .75rem;border-bottom:1px solid var(--border-primary);margin-bottom:.75rem}.sketch-canvas{width:100%;height:290px;background-color:#fff;border-radius:8px;border:1px solid var(--border-primary);cursor:crosshair}.sketch-tools{display:flex;align-items:center;gap:.75rem}.sketch-tool-label{font-size:.8rem;color:var(--text-secondary)}.sketch-tools input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:30px;height:30px;background-color:transparent;border:none;cursor:pointer}.sketch-tools input[type=color]::-webkit-color-swatch{border-radius:50%;border:2px solid var(--border-primary)}.sketch-tools input[type=color]::-moz-color-swatch{border-radius:50%;border:2px solid var(--border-primary)}.sketch-brush-slider{flex-grow:1}.sketch-tool-button{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);padding:.4rem .8rem;border-radius:8px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.sketch-tool-button:hover:not(:disabled){background-color:var(--surface-hover)}.sketch-tool-button:disabled{opacity:.5;cursor:not-allowed}.sketch-toggle-container{display:flex;align-items:center;gap:.5rem;cursor:default}.sketch-toggle-label{font-size:.8rem;color:var(--text-secondary);font-weight:400;transition:color .2s ease}.sketch-toggle-label.disabled{color:var(--surface-hover)}.switch{position:relative;display:inline-block;width:34px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--surface-secondary);transition:.4s}.slider:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:#fff;transition:.4s}input:checked+.slider{background-color:var(--primary-accent)}input:disabled+.slider{background-color:var(--surface-secondary);cursor:not-allowed}input:disabled+.slider:before{background-color:var(--surface-hover)}input:focus+.slider{box-shadow:0 0 1px var(--primary-accent)}input:checked+.slider:before{transform:translate(14px)}.slider.round{border-radius:20px}.slider.round:before{border-radius:50%}.sketch-influence-container{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-primary);transition:opacity .3s ease}.sketch-influence-container.disabled{opacity:.4;pointer-events:none}.sketch-influence-container label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:.75rem}.sketch-influence-container .influence-strength-label{margin-top:1rem}.influence-type-selector{display:flex;width:100%;background-color:var(--background-primary);border-radius:8px;border:1px solid var(--border-primary);overflow:hidden}.influence-type-selector button{flex-grow:1;padding:.5rem .25rem;font-size:.8rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;border-right:1px solid var(--border-primary)}.influence-type-selector button:last-child{border-right:none}.influence-type-selector button:hover:not(.active):not(:disabled){background-color:var(--surface-primary)}.influence-type-selector button:disabled{color:#555;cursor:not-allowed}.influence-type-selector button.active{background-color:var(--primary-accent);color:#fff;font-weight:500}.sketch-influence-container input[type=range]{width:100%;margin-bottom:.25rem}.sketch-influence-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary)}.advanced-settings-group{padding-top:1rem;border-top:1px solid var(--border-primary)}.advanced-settings-group label{font-size:.8rem;color:var(--text-secondary)}.seed-input-wrapper{position:relative;display:flex;align-items:center}.seed-input-wrapper input.read-only{background-color:var(--surface-hover);color:var(--text-secondary)}.random-seed-btn,.fix-seed-btn{position:absolute;right:0;top:0;height:100%;width:2.5rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s ease,background-color .2s ease}.random-seed-btn{right:0}.fix-seed-btn{right:2.5rem;border-right:1px solid var(--border-primary)}.random-seed-btn:hover:not(:disabled){color:var(--text-primary)}.random-seed-btn:disabled{color:#555;cursor:not-allowed}.fix-seed-btn:hover{background-color:var(--surface-secondary)}.fix-seed-btn.active{color:var(--primary-accent)}.creativity-slider-container{padding:.5rem .25rem 1rem}.creativity-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.creativity-slider-header label{font-size:.8rem;color:var(--text-secondary);margin-bottom:0}.creativity-slider-header span{font-size:.9rem;font-weight:500;background-color:var(--background-primary);padding:.2rem .5rem;border-radius:4px;border:1px solid var(--border-primary)}.creativity-slider-container input[type=range]{width:100%;margin-bottom:.25rem}.creativity-slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary)}.controls-footer{flex-shrink:0;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-primary)}.generate-btn{display:block;width:100%;padding:.9rem;font-size:1rem;font-weight:600;color:#fff;background-color:var(--primary-accent);border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease,transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.generate-btn:hover:not(:disabled){background-color:var(--primary-accent-hover);transform:translateY(-2px);box-shadow:0 4px 15px #0003}.generate-btn:disabled{background-color:var(--surface-hover);color:var(--text-secondary);cursor:not-allowed}.generate-btn.cooldown:before{content:"";position:absolute;top:0;right:0;bottom:0;background-color:#0003;animation:cooldown-animation 120s linear forwards;transform-origin:right}.generate-btn.generating{background-color:#d97706;animation:pulse-generating 2s infinite}@keyframes pulse-generating{0%{box-shadow:0 0 #d9770666}70%{box-shadow:0 0 0 10px #d9770600}to{box-shadow:0 0 #d9770600}}@keyframes cooldown-animation{0%{left:0}to{left:100%}}.main-content{flex-grow:1;height:100%;display:flex;flex-direction:column;overflow:hidden}.image-display-area{flex-grow:1;padding:2rem;display:flex;justify-content:center;align-items:center;position:relative;overflow-y:auto}.placeholder{text-align:center;color:var(--text-secondary);padding:2rem 1.5rem}.placeholder h1{margin:0 0 .25rem;letter-spacing:.2px;font-size:1.75rem;color:var(--text-primary)}.placeholder .subtitle{margin:.25rem 0 1.5rem;font-weight:500;color:var(--text-secondary)}.placeholder .tagline{font-size:1.2rem;margin-bottom:1rem;color:var(--text-primary)}.placeholder .helper{color:var(--text-secondary);margin-bottom:1.5rem}.placeholder .tips{list-style:disc;text-align:left;display:inline-block;margin:.75rem auto 1.25rem;padding-left:1.25rem;color:var(--text-secondary);opacity:.85}.placeholder .tips li{margin-bottom:.5rem}.loading-container{text-align:center;color:var(--text-secondary)}.loading-spinner{border:4px solid var(--surface-hover);border-left-color:var(--primary-accent);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:var(--error-color);background-color:#ef44441a;border:1px solid var(--error-color);padding:1rem;border-radius:8px;max-width:600px;font-size:.9rem}.generated-image-wrapper{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.generated-image-static{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 10px 20px #0003}.mix-view{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;text-align:center}.image-actions{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);opacity:0;transition:opacity .3s ease,bottom .3s ease;pointer-events:none;display:flex;gap:1rem;z-index:20}.generated-image-wrapper:hover .image-actions{opacity:1;bottom:1rem;pointer-events:all}.image-actions button,.cancel-btn{padding:.75rem 1.5rem;background-color:#1f2937cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid var(--border-primary);color:var(--text-primary);cursor:pointer;border-radius:2rem;font-size:.9rem;font-weight:500;transition:all .2s ease;box-shadow:0 4px 10px #0000004d}.image-actions button:hover:not(:disabled),.cancel-btn:hover{background-color:var(--primary-accent);border-color:var(--primary-accent);color:#fff}.image-actions button.published-btn{background-color:var(--success-color);border-color:var(--success-color);color:#fff;cursor:default}.image-actions button.published-btn:hover{background-color:var(--success-color);border-color:var(--success-color)}.mix-view h2{margin-bottom:.5rem}.mix-view p{color:var(--text-secondary);margin-bottom:1rem}.edit-actions{display:flex;gap:1rem;justify-content:center}.mix-preview-container{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;max-width:80%}.mix-preview-img{height:150px;width:auto;border-radius:8px;border:2px solid var(--border-primary);box-shadow:0 4px 10px #0003}.image-comparator{width:100%;height:100%;position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;border-radius:8px;box-shadow:0 10px 20px #0003}.image-comparator img{max-width:100%;max-height:100%;object-fit:contain;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.comparator-after{position:absolute;top:0;left:0;width:100%;height:100%}.comparator-before{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.comparator-handle{position:absolute;top:0;bottom:0;width:4px;transform:translate(-50%);cursor:ew-resize;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.comparator-line{flex-grow:1;width:2px;background:#fffc;box-shadow:0 0 5px #00000080}.comparator-arrows{background-color:#1f2937cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid var(--border-primary);border-radius:50%;width:40px;height:40px;display:flex;justify-content:center;align-items:center;box-shadow:0 0 10px #00000080;flex-shrink:0;margin:-4px 0}.comparator-label{position:absolute;bottom:1rem;background-color:#1f2937cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:#fff;padding:.25rem .75rem;border-radius:4px;font-size:.8rem;font-weight:500}.before-label{left:1rem}.after-label{right:1rem}.refinement-feedback-view{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.refinement-feedback-view h3{font-size:1.25rem;color:var(--text-primary)}.refinement-feedback-image-container{flex-grow:1;width:100%;min-height:0;position:relative}.refinement-feedback-actions{display:flex;gap:1rem;flex-shrink:0}.refinement-feedback-actions button{padding:.75rem 1.5rem;border:1px solid var(--border-primary);color:var(--text-primary);cursor:pointer;border-radius:2rem;font-size:.9rem;font-weight:600;transition:all .2s ease;box-shadow:0 4px 10px #0000004d;background-color:#1f2937cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:inline-flex;align-items:center;gap:.5rem}.refinement-feedback-actions .keep-btn{background-color:var(--success-color);border-color:var(--success-color)}.refinement-feedback-actions .keep-btn:hover{background-color:#16a34a}.refinement-feedback-actions .undo-btn{background-color:var(--surface-secondary)}.refinement-feedback-actions .undo-btn:hover{background-color:var(--surface-hover)}.refinement-feedback-actions .compare-btn:hover{background-color:var(--primary-accent);border-color:var(--primary-accent)}.inpaint-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#111827e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;justify-content:center;align-items:center;padding:2rem}.inpaint-editor-content{display:flex;flex-direction:row;gap:2rem;width:100%;height:100%}.inpaint-side-panel{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:var(--surface-primary);padding:1.5rem;border-radius:8px;border:1px solid var(--border-primary);overflow-y:auto}.inpaint-side-panel h3{margin-bottom:1rem;font-size:1.2rem}.inpaint-side-panel .error-message{margin-top:1rem}.inpaint-side-panel .generate-btn{margin-top:auto}.refinement-note{font-size:.85rem;color:var(--text-secondary);margin-top:-.5rem;margin-bottom:.75rem}.refinement-strength-container{padding:.5rem .25rem 1rem;border-top:1px solid var(--border-primary);margin-top:1rem}.refinement-strength-container label{display:block;margin-bottom:.25rem}.refinement-strength-container .creativity-slider-header{justify-content:flex-end}.refinement-strength-container .creativity-slider-header span{font-size:.9rem;font-weight:500;background-color:var(--background-primary);padding:.2rem .5rem;border-radius:4px;border:1px solid var(--border-primary)}.refinement-strength-container input[type=range]{width:100%;margin-bottom:.25rem}.refinement-strength-container .creativity-slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary)}.inpaint-main-view{flex-grow:1;display:flex;flex-direction:column;min-width:0}.inpaint-image-container{position:relative;flex-grow:1;width:100%;overflow:hidden;min-height:0;cursor:none;border-radius:8px}.inpaint-image-container:active{cursor:none}.pan-zoom-container{position:relative;transform-origin:top left}.inpaint-base-img{display:block;-webkit-user-select:none;user-select:none;pointer-events:none}.inpaint-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;pointer-events:none}.custom-brush-cursor{position:absolute;border-radius:50%;border:1px solid white;box-shadow:0 0 0 1px #000,inset 0 0 0 1px #000;background-color:#ffffff4d;pointer-events:none;transform:translate(-50%,-50%);z-index:1001}.inpaint-controls{flex-shrink:0;display:flex;align-items:center;gap:1rem;background-color:var(--surface-primary);padding:.75rem 1.5rem;border-radius:8px;border:1px solid var(--border-primary);box-shadow:0 4px 15px #0000004d;margin:1.5rem auto 0}.inpaint-controls button{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}.inpaint-controls button:hover{background-color:var(--surface-hover)}.inpaint-controls button.active{background-color:var(--primary-accent);color:#fff;border-color:var(--primary-accent)}.inpaint-view-controls{display:flex;align-items:center;gap:1rem;border-left:1px solid var(--border-primary);padding-left:1rem;margin-left:.5rem}.inpaint-view-controls span{font-size:.9rem;color:var(--text-secondary);min-width:40px;text-align:center}.brush-slider{display:flex;align-items:center;gap:.5rem}.brush-slider label{font-size:.9rem;color:var(--text-secondary)}.brush-slider input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:120px;height:8px;background:var(--surface-hover);border-radius:5px;outline:none}.brush-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--text-primary);cursor:pointer;border-radius:50%}.brush-slider input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--text-primary);cursor:pointer;border-radius:50%}.loading-container.modal-loading{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:20;border-radius:8px}.library-area{height:250px;background-color:var(--surface-primary);border-top:1px solid var(--border-primary);padding:1rem 2rem;display:flex;gap:2rem;flex-shrink:0;overflow:hidden}.folders-panel{width:200px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border-primary);padding-right:2rem}.folders-panel h3{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.folder-item{padding:.5rem;border-radius:6px;cursor:pointer;transition:background-color .2s ease,color .2s ease;font-size:.9rem;margin-bottom:.25rem}.folder-item:hover{background-color:var(--surface-secondary)}.folder-item.active{background-color:var(--primary-accent);color:#fff;font-weight:500}.folder-item.drag-over{outline:2px dashed var(--primary-accent);outline-offset:-2px}.new-folder-controls{margin-top:auto}.new-folder-btn{width:100%;padding:.5rem;border:1px dashed var(--border-primary);background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;text-align:center;transition:all .2s ease}.new-folder-btn:hover{background-color:var(--surface-secondary);border-color:var(--primary-accent);color:var(--text-primary)}.new-folder-form{display:flex;gap:.5rem}.new-folder-form input{flex-grow:1;background:var(--background-primary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:6px;padding:.4rem .6rem;font-size:.9rem;min-width:0}.new-folder-form input:focus{outline:none;border-color:var(--primary-accent)}.new-folder-form button{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:6px;cursor:pointer;width:30px;height:30px;flex-shrink:0;transition:all .2s ease}.new-folder-form button:hover{background-color:var(--primary-accent);border-color:var(--primary-accent)}.library-content{flex-grow:1;display:flex;flex-direction:column;min-width:0}.library-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-shrink:0;flex-wrap:wrap}.library-area h2{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:0;flex-shrink:0}.shared-gallery-btn{padding:.4rem 1rem;font-size:.85rem;border:1px solid var(--border-primary);background-color:var(--surface-secondary);color:var(--text-primary);border-radius:8px;cursor:pointer;transition:all .2s ease}.shared-gallery-btn:hover{background-color:var(--primary-accent);border-color:var(--primary-accent);color:#fff}.library-search{flex-grow:1;background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);padding:.4rem .8rem;font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease}.library-search:focus{outline:none;border-color:var(--primary-accent);box-shadow:0 0 0 2px var(--focus-ring-color)}.library-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.mix-btn,.download-selected-btn,.select-all-btn,.publish-selected-btn{padding:.4rem 1rem;font-size:.85rem;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.mix-btn{background-color:var(--primary-accent);color:#fff}.mix-btn:hover:not(:disabled){background-color:var(--primary-accent-hover)}.mix-btn:disabled{background-color:var(--surface-hover);color:var(--text-secondary);cursor:not-allowed}.download-selected-btn,.select-all-btn{background-color:var(--surface-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.download-selected-btn:hover:not(:disabled),.select-all-btn:hover{background-color:var(--surface-hover);border-color:#555}.download-selected-btn:disabled{background-color:var(--surface-secondary);color:var(--text-secondary);cursor:not-allowed}.publish-selected-btn{background-color:var(--success-color);color:#fff}.publish-selected-btn:hover:not(:disabled){background-color:#16a34a}.publish-selected-btn:disabled{background-color:var(--surface-hover);color:var(--text-secondary);cursor:not-allowed}.library-grid{display:flex;gap:1rem;overflow-x:auto;padding-bottom:1rem}.library-item{width:200px;height:150px;flex-shrink:0;position:relative;border-radius:8px;overflow:hidden;background-color:var(--background-primary);border:2px solid transparent;transition:border-color .2s ease}.library-item.selected{border-color:var(--primary-accent)}.library-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease,filter .3s ease;cursor:pointer}.library-item:hover img{transform:scale(1.05);filter:brightness(.4)}.library-item-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;color:#fff;font-weight:600;opacity:0;transition:opacity .3s ease;pointer-events:none}.library-item:hover .library-item-overlay{opacity:1}.selection-box{position:absolute;top:8px;left:8px;width:22px;height:22px;background-color:#00000080;border:2px solid #fff;border-radius:4px;cursor:pointer;display:flex;justify-content:center;align-items:center;color:#fff;font-size:16px;font-weight:700;transition:background-color .2s ease;z-index:2}.library-item.selected .selection-box,.selection-box:hover{background-color:var(--primary-accent);border-color:var(--primary-accent)}.delete-btn{position:absolute;top:8px;right:8px;background:#00000080;color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:14px;line-height:22px;text-align:center;cursor:pointer;transition:background .2s ease;opacity:.6;z-index:2}.library-item:hover .delete-btn{opacity:1}.delete-btn:hover{background:var(--error-color)}.empty-library-text{color:var(--text-secondary);font-size:.9rem;width:100%;text-align:center;padding:2rem 0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background-primary)}::-webkit-scrollbar-thumb{background:var(--surface-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.api-key-prompt-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#111827e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:3000}.api-key-prompt-content{background-color:var(--surface-primary);padding:2.5rem;border-radius:8px;border:1px solid var(--border-primary);width:90%;max-width:480px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;gap:1rem;text-align:center}.api-key-prompt-content h2{margin-bottom:.5rem}.api-key-prompt-content p{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin-bottom:1rem}.api-key-prompt-content p a{color:var(--primary-accent);text-decoration:none}.api-key-prompt-content p a:hover{text-decoration:underline}.api-key-prompt-form{display:flex;flex-direction:column;gap:1rem;width:100%}.api-key-prompt-form input{width:100%;padding:.75rem;background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:1rem;font-family:Inter,sans-serif;transition:border-color .2s ease,box-shadow .2s ease}.api-key-prompt-form input:focus{outline:none;border-color:var(--primary-accent);box-shadow:0 0 0 3px var(--focus-ring-color)}.api-key-prompt-actions{display:flex;justify-content:center;align-items:center;margin-top:1rem}.api-key-prompt-actions .primary-btn{width:100%}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#111827e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:2600}.modal-content{background-color:var(--surface-primary);padding:2rem;border-radius:8px;border:1px solid var(--border-primary);width:90%;max-width:600px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column}.modal-content h2{margin-bottom:1.5rem}.modal-content h3{font-size:1rem;font-weight:600;margin-bottom:1rem;border-bottom:1px solid var(--border-primary);padding-bottom:.75rem}.visual-type-list{max-height:30vh;overflow-y:auto;margin-bottom:1.5rem;border:1px solid var(--border-primary);border-radius:8px;padding:.5rem;background-color:var(--background-primary)}.visual-type-item{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem;border-bottom:1px solid var(--border-primary)}.visual-type-item:last-child{border-bottom:none}.visual-type-display{flex-grow:1}.visual-type-name{font-weight:600;display:block;margin-bottom:.25rem}.visual-type-prompt-preview{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:350px}.visual-type-edit-form{flex-grow:1;display:flex;flex-direction:column;gap:.5rem}.visual-type-edit-form input,.visual-type-edit-form textarea{background:var(--surface-secondary);border:1px solid var(--surface-hover);color:var(--text-primary);border-radius:6px;padding:.6rem .8rem;font-size:.9rem;width:100%}.visual-type-edit-form input:focus,.visual-type-edit-form textarea:focus{outline:none;border-color:var(--primary-accent)}.prompt-template-input{min-height:80px;resize:vertical;font-family:Inter,sans-serif}.prompt-template-help{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem}.prompt-template-help strong{color:var(--text-primary);font-family:monospace}.visual-type-actions{display:flex;gap:.5rem;padding-left:1rem}.visual-type-actions button{background:none;border:1px solid var(--border-primary);color:var(--text-secondary);padding:.3rem .6rem;font-size:.75rem;border-radius:6px;cursor:pointer;transition:all .2s ease}.visual-type-actions button:hover{background-color:var(--surface-secondary);border-color:#555;color:var(--text-primary)}.visual-type-actions button.delete:hover{background-color:var(--error-color);border-color:var(--error-color);color:#fff}.visual-type-add-form{display:flex;gap:1rem;margin-bottom:1.5rem;border-top:1px solid var(--border-primary);padding-top:1.5rem}.visual-type-add-inputs{flex-grow:1;display:flex;flex-direction:column;gap:.5rem}.visual-type-add-inputs input,.visual-type-add-inputs textarea{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:8px;padding:.6rem .8rem;font-size:1rem}.visual-type-add-form button{padding:0 1.5rem;background-color:var(--primary-accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease;align-self:flex-start;height:46px}.visual-type-add-form button:hover{background-color:var(--primary-accent-hover)}.style-from-image-section{margin-bottom:1.5rem;border-top:1px solid var(--border-primary);padding-top:1.5rem}.style-from-image-content{display:flex;gap:1rem;align-items:flex-start}.style-image-upload-placeholder{width:120px;height:120px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;align-items:center;border:2px dashed var(--border-primary);border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.style-image-upload-placeholder:hover{border-color:var(--primary-accent);color:var(--primary-accent);background-color:#3b82f60d}.style-image-upload-placeholder span{font-size:2rem;line-height:1}.style-image-upload-placeholder p{margin-top:.25rem;font-size:.8rem}.style-image-preview-container{width:120px;height:120px;flex-shrink:0;background-color:var(--background-primary);border-radius:8px;overflow:hidden}.style-image-preview-container img{width:100%;height:100%;object-fit:cover}.style-from-image-actions{flex-grow:1}.style-from-image-actions button{width:100%}.modal-error-message{font-size:.8rem;color:var(--error-color);margin-top:.75rem}.modal-footer{display:flex;justify-content:flex-end;align-items:center;margin-top:1rem;gap:.75rem}.modal-footer-group{display:flex;gap:.5rem}.modal-footer:first-child:not(:only-child){margin-right:auto}.modal-footer button,.api-key-prompt-actions button{padding:.7rem 1.5rem;font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.modal-footer button.primary-btn,.api-key-prompt-actions button.primary-btn{color:#fff;background-color:var(--primary-accent);border-color:var(--primary-accent)}.modal-footer button.primary-btn:hover,.api-key-prompt-actions button.primary-btn:hover{background-color:var(--primary-accent-hover)}.modal-footer button.secondary-btn{color:var(--text-primary);background-color:var(--surface-secondary);border-color:var(--border-primary)}.modal-footer button.secondary-btn:hover{background-color:var(--surface-hover)}.prompt-manager-list{max-height:50vh;overflow-y:auto;margin-bottom:1.5rem;border:1px solid var(--border-primary);border-radius:8px;padding:.5rem;background-color:var(--background-primary)}.prompt-manager-category{padding:1rem;border-bottom:1px solid var(--border-primary)}.prompt-manager-category:last-child{border-bottom:none}.prompt-manager-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.prompt-manager-category-header h3{margin:0;padding:0;border:none;font-size:1.1rem}.delete-category-btn{background:none;border:1px solid var(--border-primary);color:var(--text-secondary);padding:.3rem .6rem;font-size:.75rem;border-radius:6px;cursor:pointer;transition:all .2s ease}.delete-category-btn:hover{background-color:var(--error-color);border-color:var(--error-color);color:#fff}.suggestion-chip-editable{display:inline-flex;align-items:center;background-color:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-secondary);padding:.25rem .5rem .25rem .75rem;font-size:.8rem;border-radius:1rem;margin:0 .5rem .5rem 0}.suggestion-chip-editable button{background:none;border:none;color:var(--text-secondary);cursor:pointer;margin-left:.5rem;font-size:1rem;line-height:1;padding:0;opacity:.7}.suggestion-chip-editable button:hover{color:var(--error-color);opacity:1}.add-suggestion-form{display:flex;gap:.5rem;margin-top:1rem}.add-suggestion-form input{flex-grow:1;background:var(--surface-secondary);border:1px solid var(--surface-hover);color:var(--text-primary);border-radius:6px;padding:.4rem .6rem;font-size:.9rem}.add-suggestion-form button{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:6px;cursor:pointer;width:30px;height:30px;flex-shrink:0;transition:all .2s ease}.add-suggestion-form button:hover{background-color:var(--primary-accent);border-color:var(--primary-accent)}.add-category-form{display:flex;gap:1rem;padding:1.5rem 0;border-top:1px solid var(--border-primary)}.add-category-form input{flex-grow:1;background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:8px;padding:.6rem .8rem;font-size:1rem}.add-category-form button{padding:0 1.5rem;background-color:var(--primary-accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.add-category-form button:hover{background-color:var(--primary-accent-hover)}.whitelist-list{max-height:50vh;overflow-y:auto;margin-bottom:1.5rem;border:1px solid var(--border-primary);border-radius:8px;padding:.5rem;background-color:var(--background-primary)}.whitelist-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-bottom:1px solid var(--border-primary)}.whitelist-item:last-child{border-bottom:none}.whitelist-item-email{font-size:.9rem;color:var(--text-primary)}.whitelist-item-actions button{background:none;border:1px solid var(--border-primary);color:var(--text-secondary);padding:.3rem .6rem;font-size:.75rem;border-radius:6px;cursor:pointer;transition:all .2s ease}.whitelist-item-actions button:hover{background-color:var(--error-color);border-color:var(--error-color);color:#fff}.add-whitelist-form{display:flex;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--border-primary);align-items:flex-start}.add-whitelist-form input,.add-whitelist-form textarea{flex-grow:1;background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:8px;padding:.6rem .8rem;font-size:1rem;font-family:Inter,sans-serif;resize:vertical}.add-whitelist-form textarea{min-height:80px}.add-whitelist-form button{padding:0 1.5rem;background-color:var(--primary-accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;height:46px;flex-shrink:0}.add-whitelist-form button:hover:not(:disabled){background-color:var(--primary-accent-hover)}.add-whitelist-form button:disabled{background-color:var(--surface-hover);color:var(--text-secondary);cursor:not-allowed}.summary-title-wrapper{display:flex;align-items:center;gap:.5rem}.input-group>label.summary-title-wrapper{display:inline-flex}.activation-indicator{width:8px;height:8px;border-radius:50%;background-color:var(--surface-hover);transition:background-color .3s ease}.activation-indicator.active{background-color:var(--primary-accent)}.cost-estimator{display:flex;justify-content:space-between;align-items:center;background-color:var(--background-primary);border:1px solid var(--border-primary);border-radius:8px;padding:.75rem;flex-shrink:0;margin-bottom:1rem}.cost-estimator label{font-size:.85rem;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem;margin:0}.cost-estimator .tooltip{position:relative;display:inline-flex;justify-content:center;align-items:center;width:16px;height:16px;border-radius:50%;background-color:var(--surface-secondary);color:var(--text-secondary);font-size:.7rem;font-weight:700;cursor:help;border:1px solid var(--border-primary)}.cost-estimator .tooltip .tooltip-text{visibility:hidden;width:220px;background-color:var(--surface-secondary);color:var(--text-primary);text-align:center;border-radius:6px;padding:8px;position:absolute;z-index:1;bottom:125%;left:50%;margin-left:-110px;opacity:0;transition:opacity .3s;font-size:.75rem;font-weight:400;box-shadow:0 5px 15px #0000004d}.cost-estimator .tooltip:hover .tooltip-text{visibility:visible;opacity:1}.cost-estimator .cost-value{font-size:1rem;font-weight:600;color:var(--text-primary)}.disclaimer-footer{margin-top:1rem;text-align:center}.disclaimer-footer p{font-size:.75rem;color:var(--text-secondary);opacity:.8;line-height:1.4}.error-toast-container{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:5000;display:flex;justify-content:center;align-items:center;pointer-events:none}.error-toast{display:flex;align-items:center;gap:1rem;background-color:var(--error-color);color:var(--text-primary);padding:.75rem 1rem;border-radius:8px;box-shadow:0 5px 15px #0000004d;pointer-events:all;animation:slide-in .3s ease-out forwards;max-width:90vw;max-width:600px;font-size:.9rem;text-align:left}@keyframes slide-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.error-toast span{flex-grow:1}.error-toast button{background:none;border:none;color:var(--text-primary);font-size:1.2rem;line-height:1;cursor:pointer;opacity:.7;transition:opacity .2s ease;padding:.25rem}.error-toast button:hover{opacity:1}.gallery-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#111827f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2500;display:flex;justify-content:center;align-items:center}.gallery-modal-content{width:100%;height:100%;display:flex;flex-direction:column;padding:2rem}.gallery-modal-header{flex-shrink:0;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-primary)}.gallery-modal-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.gallery-modal-title h2{font-size:1.5rem}.gallery-disclaimer{color:var(--text-secondary);font-size:.9rem}.gallery-close-btn{background:none;border:none;color:var(--text-secondary);font-size:2rem;cursor:pointer;transition:color .2s ease}.gallery-close-btn:hover{color:var(--text-primary)}.gallery-modal-filters{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-size:.8rem;color:var(--text-secondary)}.filter-group input,.filter-group select{background-color:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:6px;padding:.4rem .6rem;font-size:.9rem}.filter-group input{min-width:200px}.filter-group select{min-width:150px}.input-with-clear{position:relative}.input-with-clear input{padding-right:2rem}.clear-filter-btn{position:absolute;right:0;top:0;height:100%;width:2rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.2rem;transition:color .2s ease}.clear-filter-btn:hover{color:var(--text-primary)}.user-filter-container{display:flex;gap:.5rem}.user-filter-container input{flex-grow:1}.my-images-btn{padding:0 1rem;background-color:var(--surface-hover);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.9rem;flex-shrink:0}.my-images-btn:hover{background-color:var(--primary-accent);border-color:var(--primary-accent)}.filter-group.checkbox-filter{flex-direction:row;align-items:center;gap:.5rem;padding-bottom:.4rem}.filter-group.checkbox-filter label{margin-bottom:0;cursor:pointer;font-weight:500}.filter-group.checkbox-filter input{width:16px;height:16px;cursor:pointer}.gallery-grid-container{flex-grow:1;overflow-y:auto;padding-right:1rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.gallery-item{position:relative;aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;background-color:var(--background-primary);box-shadow:0 5px 15px #0003;cursor:pointer}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-item:hover img{transform:scale(1.05)}.gallery-item-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top,#000c,#0000 50%);opacity:0;transition:opacity .3s ease;display:flex;flex-direction:column;justify-content:flex-end;padding:1rem;pointer-events:none}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-info{color:#fff;font-size:.85rem;margin-bottom:.75rem;padding:.5rem;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:6px}.gallery-item-prompt,.gallery-item-vtype{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-item-prompt{margin-bottom:.25rem}.gallery-item-prompt strong,.gallery-item-vtype strong{color:var(--text-secondary)}.gallery-item-actions{display:flex;gap:.75rem;width:100%;align-items:stretch;pointer-events:all}.gallery-source-badge{position:absolute;top:8px;left:8px;background-color:#1f2937cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:var(--text-primary);padding:.25rem .6rem;border-radius:4px;font-size:.75rem;font-weight:500;z-index:3;display:flex;align-items:center;gap:.3rem;pointer-events:none}.gallery-source-badge svg{width:12px;height:12px}.gallery-source-badge.type-text{background-color:#3b82f6b3}.gallery-source-badge.type-image{background-color:#22c55eb3}.gallery-source-badge.type-brush{background-color:#ec4899b3}.gallery-source-badge.type-mix{background-color:#d97706b3}.gallery-item-delete-btn{position:absolute;top:8px;right:8px;background:#00000080;color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:16px;line-height:24px;text-align:center;cursor:pointer;transition:all .2s ease;opacity:0;z-index:5;pointer-events:all}.gallery-item:hover .gallery-item-delete-btn{opacity:.8}.gallery-item-delete-btn:hover{background:var(--error-color);opacity:1;transform:scale(1.1)}.action-with-counter{display:flex;align-items:center;gap:.3rem;background-color:var(--primary-accent);border-radius:8px;flex-grow:1;overflow:hidden;transition:background-color .2s ease}.action-with-counter:hover{background-color:var(--primary-accent-hover)}.gallery-use-btn{flex-grow:1;padding:.6rem;border:none;font-weight:600;cursor:pointer;background-color:transparent;color:#fff;transition:background-color .2s ease}.action-with-counter:hover .gallery-use-btn{background-color:#0000001a}.action-counter{font-size:.8rem;font-weight:600;color:#fffc;padding-right:.6rem}.action-with-counter.like-container{background-color:var(--surface-secondary);flex-grow:0}.action-with-counter.like-container:hover{background-color:var(--surface-hover)}.gallery-like-btn{background:transparent;border:none;cursor:pointer;padding:.4rem .2rem .4rem .6rem;display:flex;align-items:center;justify-content:center}.gallery-like-btn svg{width:18px;height:18px}.gallery-like-btn svg path{fill:none;stroke:var(--text-secondary);stroke-width:2;transition:fill .2s ease,stroke .2s ease}.gallery-like-btn:hover svg path{stroke:var(--error-color)}.gallery-like-btn.liked svg path{fill:var(--error-color);stroke:var(--error-color)}.action-with-counter.like-container .action-counter{color:var(--text-primary);padding-right:.75rem}.gallery-history-btn,.gallery-similar-btn{flex-grow:0;padding:.6rem;width:38px;height:38px;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease;background-color:var(--surface-secondary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:0;pointer-events:all}.gallery-history-btn:hover,.gallery-similar-btn:hover{background-color:var(--surface-hover)}.gallery-preview-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#111827e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2800;display:flex;justify-content:center;align-items:center;padding:2rem}.gallery-preview-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem}.gallery-preview-content .image-comparator,.gallery-preview-image{max-width:90%;max-height:85%;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 10px 30px #0000004d}.gallery-preview-content .image-comparator{width:80vw;height:80vh}.gallery-preview-close-btn{position:absolute;top:-.5rem;right:-.5rem;background:var(--surface-primary);border:1px solid var(--border-primary);color:var(--text-primary);font-size:1.5rem;cursor:pointer;transition:all .2s ease;border-radius:50%;width:40px;height:40px;display:flex;justify-content:center;align-items:center;z-index:10}.gallery-preview-close-btn:hover{background-color:var(--error-color);transform:scale(1.1)}.gallery-preview-info{background-color:#1f2937cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:.75rem 1.25rem;border-radius:8px;color:var(--text-primary);max-width:80%;text-align:center;font-size:.9rem}.gallery-preview-info p{margin:.25rem 0}.lineage-viewer-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#111827f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2700;display:flex;justify-content:center;align-items:center;padding:2rem}.lineage-viewer-content{background-color:var(--surface-primary);padding:2rem;border-radius:8px;border:1px solid var(--border-primary);width:90%;max-width:1200px;height:90%;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;position:relative}.lineage-viewer-close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-secondary);font-size:2rem;cursor:pointer;transition:color .2s ease;z-index:10}.lineage-viewer-close-btn:hover{color:var(--text-primary)}.lineage-viewer-main-image{flex-grow:1;display:flex;justify-content:center;align-items:center;min-height:0;margin-bottom:1.5rem;position:relative}.lineage-viewer-main-image img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 5px 20px #0000004d;transition:opacity .3s ease}.lineage-viewer-main-image .action-with-counter{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);min-width:150px;box-shadow:0 4px 10px #0000004d}.lineage-viewer-trail-container{flex-shrink:0;border-top:1px solid var(--border-primary);padding-top:1.5rem}.lineage-viewer-trail-container h3{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.lineage-viewer-trail{display:flex;align-items:center;gap:1rem;overflow-x:auto;padding-bottom:1rem}.lineage-trail-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer}.lineage-trail-thumbnail{width:80px;height:80px;border-radius:6px;border:2px solid var(--border-primary);object-fit:cover;flex-shrink:0;transition:border-color .2s ease,transform .2s ease}.lineage-trail-item:hover .lineage-trail-thumbnail{border-color:var(--primary-accent-hover);transform:scale(1.05)}.lineage-trail-thumbnail.active{border-color:var(--primary-accent);transform:scale(1.05);box-shadow:0 0 8px var(--focus-ring-color)}.lineage-trail-prompt{font-size:.75rem;color:var(--text-secondary);text-align:center;width:80px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lineage-trail-separator{color:var(--text-secondary);font-weight:700;font-size:1.5rem;flex-shrink:0}.delete-confirm-modal{max-width:400px;text-align:center}.delete-confirm-preview{margin:1.5rem 0;display:flex;justify-content:center}.delete-confirm-preview img{max-width:150px;max-height:150px;border-radius:8px;border:1px solid var(--border-primary)}.modal-footer .delete-btn-confirm{background-color:var(--error-color);border-color:var(--error-color);color:#fff}.modal-footer .delete-btn-confirm:hover{background-color:#b91c1c;border-color:#b91c1c}.request-queue-panel{position:fixed;bottom:0;left:0;width:100%;max-height:320px;background-color:var(--surface-primary);border-top:2px solid var(--primary-accent);z-index:500;display:flex;flex-direction:column;box-shadow:0 -5px 20px #0000004d;transition:max-height .3s ease-in-out}.request-queue-panel.collapsed{max-height:50px}.request-queue-header{display:flex;justify-content:space-between;align-items:center;flex-shrink:0;padding:.5rem 1.5rem;cursor:pointer;height:50px}.request-queue-header h2{font-size:1.2rem;color:var(--text-primary);margin-right:1rem}.request-queue-header-controls{display:flex;align-items:center;gap:1rem;margin-left:auto}.queue-toggle-btn{background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:50%;width:32px;height:32px;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:transform .3s ease,background-color .2s ease}.queue-toggle-btn:hover{background-color:var(--surface-hover)}.request-queue-panel.collapsed .queue-toggle-btn{transform:rotate(180deg)}.queue-count{font-size:1rem;background-color:var(--primary-accent);color:#fff;padding:.2rem .7rem;border-radius:1rem;font-weight:600}.request-queue-controls-bar{display:flex;gap:1.5rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border-primary);flex-shrink:0;align-items:center}.queue-control-item{display:flex;align-items:center;gap:.5rem}.queue-control-item label{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.queue-control-item select{background-color:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:6px;padding:.4rem .6rem;font-size:.9rem}.queue-control-item-group{margin-left:auto;display:flex;gap:.75rem}.queue-control-item-group button{padding:.5rem 1rem;background-color:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);font-size:.85rem;border-radius:6px;cursor:pointer;transition:all .2s ease}.queue-control-item-group button:hover{background-color:var(--surface-hover)}.queue-settings-modal{max-width:500px}.queue-settings-modal h3{font-size:1rem;font-weight:600;margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-primary);color:var(--text-secondary)}.queue-settings-modal .modal-content h3:first-of-type{margin-top:0}.settings-group{display:flex;flex-direction:column;gap:1rem}.setting-item{background-color:var(--background-primary);padding:1rem;border-radius:8px;border:1px solid var(--border-primary)}.setting-item .sketch-toggle-container{display:flex;justify-content:space-between;align-items:center}.setting-item .sketch-toggle-label{font-size:.9rem;font-weight:500;color:var(--text-primary)}.setting-description{font-size:.8rem;color:var(--text-secondary);margin-top:.5rem}.auto-queue-limits{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;transition:opacity .3s ease}.auto-queue-limits.disabled{opacity:.5;pointer-events:none}.auto-queue-limits .input-group{margin:0;display:flex;align-items:center;gap:.5rem}.auto-queue-limits .input-group label{font-size:.85rem;margin:0}.auto-queue-limits input{width:70px;padding:.4rem .6rem}.danger-zone{border-color:var(--error-color);display:flex;justify-content:space-between;align-items:center}.danger-zone-info{text-align:left}.danger-zone-info h4{color:var(--error-color);margin-bottom:.25rem}.danger-zone .clear-queue-btn{background-color:var(--error-color);border:1px solid var(--error-color);color:#fff;padding:.6rem 1rem;font-weight:600;border-radius:6px;cursor:pointer;transition:background-color .2s ease;flex-shrink:0;margin-left:1rem}.danger-zone .clear-queue-btn:hover{background-color:#b91c1c}.request-queue-list{flex-grow:1;overflow-y:auto;padding:1rem 1.5rem}.request-user-group{background-color:var(--background-primary);border:1px solid var(--border-primary);border-radius:8px;margin-bottom:1rem}.request-user-group-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;cursor:pointer;background-color:var(--surface-primary);border-bottom:1px solid var(--border-primary);transition:background-color .2s ease}.request-user-group[open]>.request-user-group-header{border-bottom-color:var(--border-primary)}.request-user-group-header:hover{background-color:var(--surface-hover)}.request-user-group-header-info{display:flex;align-items:center;gap:.75rem;flex-grow:1}.request-item-avatar{width:32px;height:32px;border-radius:50%}.request-user-group-header-details{display:flex;flex-direction:column}.request-user-group-header-name{font-weight:500}.request-user-group-header-meta{font-size:.8rem;color:var(--text-secondary);display:flex;gap:.75rem}.request-user-group-header-actions{display:flex;gap:.5rem}.request-user-group-header-actions button{padding:.5rem 1rem;border-radius:6px;cursor:pointer;border:1px solid transparent;font-weight:600;transition:all .2s ease;font-size:.85rem}.request-user-group-header-actions .generate-latest{background-color:var(--success-color);border-color:var(--success-color);color:#fff}.request-user-group-header-actions .generate-latest:hover{background-color:#16a34a}.request-user-group-header-actions .reject-all{background-color:var(--surface-secondary);border-color:var(--border-primary);color:var(--text-primary)}.request-user-group-header-actions .reject-all:hover{background-color:var(--error-color);border-color:var(--error-color)}.request-user-group-content{padding:.5rem 1rem 1rem;display:flex;flex-direction:column;gap:.75rem}.request-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background-color:var(--surface-secondary);border-radius:6px;border:1px solid var(--border-primary)}.request-item-timestamp{font-size:.8rem;color:var(--text-secondary);flex-shrink:0;width:60px;text-align:right}.request-item-prompt{flex-grow:1;display:flex;align-items:center;gap:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.engine-badge{padding:.2rem .5rem;font-size:.7rem;font-weight:600;border-radius:4px;flex-shrink:0}.engine-badge.gemini{background-color:#3b82f633;color:var(--primary-accent)}.engine-badge.imagen{background-color:#ec489933;color:#ec4899}.request-item-inputs{display:flex;gap:.5rem;flex-shrink:0}.request-item-inputs img{width:40px;height:40px;object-fit:cover;border-radius:4px;border:1px solid var(--border-primary)}.request-item-actions{display:flex;gap:.5rem;flex-shrink:0}.request-item-actions button{padding:.4rem .8rem;border-radius:6px;cursor:pointer;border:1px solid transparent;font-weight:500;transition:all .2s ease;font-size:.8rem}.request-item-actions .generate{background-color:var(--primary-accent);border-color:var(--primary-accent);color:#fff}.request-item-actions .generate:hover:not(:disabled){background-color:var(--primary-accent-hover)}.request-item-actions .reject{background-color:var(--surface-hover);border-color:var(--border-primary);color:var(--text-primary)}.request-item-actions .reject:hover:not(:disabled){background-color:var(--error-color);border-color:var(--error-color)}.request-item-actions button:disabled{opacity:.5;cursor:not-allowed}.statistics-modal-content{max-width:1000px;width:90%;max-height:90vh}.stats-container{display:flex;flex-direction:column;gap:2rem;margin-bottom:1.5rem}.stats-section{background-color:var(--background-primary);border:1px solid var(--border-primary);border-radius:8px;padding:1.5rem}.stats-section.glance{background-color:transparent;border:none;padding:0}.glance-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}.glance-card{background-color:var(--surface-primary);padding:1.5rem 1rem;border-radius:8px;border:1px solid var(--border-primary);display:flex;flex-direction:column;justify-content:center;transition:all .2s ease-in-out}.glance-card:hover{transform:translateY(-4px);border-color:var(--primary-accent)}.glance-value{font-size:3rem;font-weight:700;line-height:1.1;color:var(--text-primary);margin-bottom:.5rem}.glance-card:first-child .glance-value{color:var(--primary-accent)}.glance-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.leaderboards{display:grid;grid-template-columns:1fr 1.5fr;gap:2rem;align-items:flex-start}.leaderboard-column>h3{font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-primary);color:var(--text-secondary)}.leaderboard-list{list-style:none;padding:0;margin:0;flex-grow:1;display:flex;flex-direction:column;gap:.75rem}.leaderboard-item{display:flex;align-items:center;gap:.75rem;background-color:var(--surface-primary);padding:.5rem .75rem;border-radius:6px}.leaderboard-avatar{width:32px;height:32px;border-radius:50%}.leaderboard-name{flex-grow:1;font-weight:500}.leaderboard-count{font-size:.9rem;color:var(--text-secondary);font-weight:500}.popular-images-container{display:flex;flex-direction:column;gap:1.5rem;flex-grow:1}.popular-image-container{display:flex;gap:1.5rem;align-items:center;background-color:var(--surface-primary);padding:1rem;border-radius:6px;border:1px solid transparent}.popular-image-container.popular-image-placeholder{align-items:flex-start;flex-direction:column;gap:0}.popular-image-placeholder .stat-placeholder{width:100%;min-height:100px}.popular-image-preview{width:120px;height:120px;object-fit:cover;border-radius:6px;border:1px solid var(--border-primary);flex-shrink:0}.popular-image-info{font-size:.9rem;color:var(--text-secondary)}.popular-image-info h4{font-size:1.1rem;font-weight:600;margin-bottom:.75rem;color:var(--text-secondary)}.popular-image-info p{margin-bottom:.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.popular-image-info p strong{color:var(--text-primary);font-weight:500}.popular-image-count{font-size:1.2rem;font-weight:700;color:var(--primary-accent);margin-top:.75rem!important}.stat-placeholder{color:var(--text-secondary);text-align:center;flex-grow:1;display:flex;align-items:center;justify-content:center}
