.auth-container{align-items:center;background-color:#1a1a1a;display:flex;justify-content:center;min-height:100vh}.auth-card{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 4px 20px #00000080;max-width:400px;padding:2rem;width:100%}.auth-card h2{color:#e0e0e0;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1rem}.form-group label{color:#b0b0b0;display:block;font-weight:500;margin-bottom:.5rem}.form-group input{background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;box-sizing:border-box;color:#e0e0e0;font-size:1rem;padding:.75rem;width:100%}.form-group input:focus{background-color:#222;border-color:#4caf50;outline:none}.btn-primary{border:none;cursor:pointer;font-size:1rem;font-weight:600;transition:background-color .3s;width:100%}.btn-primary,.error-message{border-radius:4px;padding:.75rem}.error-message{background-color:#3d1a1a;border:1px solid #5a2020;color:#ff6b6b;margin-bottom:1rem}.auth-link{color:#888;margin-top:1rem;text-align:center}.auth-link a{color:#4caf50;font-weight:500;text-decoration:none}.auth-link a:hover{text-decoration:underline}.generation-menu-wrapper{align-items:flex-start;display:flex;gap:2rem;width:100%}.generation-menu{flex:1 1;padding:2rem}.generation-menu,.reference-gallery-container{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 4px 20px #00000080;box-sizing:border-box}.reference-gallery-container{display:flex;flex-direction:column;max-height:800px;padding:.75rem;width:130px}.reference-gallery-container h3{color:#e0e0e0;font-size:.85rem;margin:0 0 .25rem;text-align:center}.reference-gallery-list{display:flex;flex:1 1;flex-direction:column;gap:.5rem;margin-top:1rem;overflow-y:auto;padding-right:.5rem}.reference-thumbnail-vertical{aspect-ratio:1;border:2px solid #3a3a3a;border-radius:4px;cursor:pointer;flex-shrink:0;overflow:hidden;position:relative;transition:all .3s;width:100%}.reference-thumbnail-vertical:hover{border-color:#4caf50}.reference-thumbnail-vertical.selected{border-color:#4caf50;box-shadow:inset 0 0 0 1px #4caf50}.reference-thumbnail-vertical.deselected{border-color:#666;opacity:.4}.reference-thumbnail-vertical.deselected img{filter:grayscale(80%)}.reference-thumbnail-vertical img{height:100%;object-fit:cover;transition:filter .3s;width:100%}.reference-thumbnail-vertical .delete-reference-btn{align-items:center;background:#ff5252e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:20px;justify-content:center;line-height:1;opacity:0;position:absolute;right:4px;top:4px;transition:opacity .3s;width:20px}.reference-thumbnail-vertical:hover .delete-reference-btn{opacity:1}.reference-thumbnail-vertical .delete-reference-btn:hover{background:#ff1744e6}.reference-gallery-list::-webkit-scrollbar{width:8px}.reference-gallery-list::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.reference-gallery-list::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.reference-gallery-list::-webkit-scrollbar-thumb:hover{background:#666}.reference-gallery-item{background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:6px;display:flex;flex-direction:column;overflow:hidden}.generation-menu h2{color:#e0e0e0;margin-bottom:1.5rem}.form-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.form-column-left,.form-column-right{display:flex;flex-direction:column}.generation-form .form-group{margin-bottom:1.5rem}.generation-form label{color:#b0b0b0;display:block;font-weight:500;margin-bottom:.5rem}.prompt-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.prompt-header label{margin-bottom:0}.prompt-actions{display:flex;gap:.5rem}.btn-copy-prompt-full{background-color:#2f4f2f;border:1px solid #4caf50;border-radius:4px;color:#cfe8cf;cursor:pointer;font-size:.875rem;font-weight:600;padding:.4rem .75rem;transition:all .3s}.btn-copy-prompt-full:hover{background-color:#4caf501a;border-color:#45a049;color:#a7d7a7}.btn-erase-prompt{background-color:#555;border:1px solid #666;border-radius:4px;color:#b0b0b0;cursor:pointer;font-size:.875rem;font-weight:500;padding:.4rem .75rem;transition:all .3s}.btn-erase-prompt:hover{background-color:#666;border-color:#777;color:#e0e0e0}.generation-form input[type=file],.generation-form input[type=number],.generation-form select,.generation-form textarea{background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;box-sizing:border-box;color:#e0e0e0;font-family:inherit;font-size:1rem;padding:.75rem;width:100%}.generation-form textarea{resize:vertical}.generation-form input[type=number]:focus,.generation-form select:focus,.generation-form textarea:focus{background-color:#222;border-color:#4caf50;outline:none}.file-name,.quantity-note{color:#888;font-size:.875rem;margin-top:.5rem}.quantity-note{font-style:italic;margin-bottom:0}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-actions{justify-content:center;margin-top:1rem}.btn-generate{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 3rem;transition:background-color .3s}.btn-generate:hover:not(:disabled){background-color:#45a049}.btn-generate:disabled{background-color:#555;cursor:not-allowed}.project-references-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin-top:.5rem}.reference-gallery-header{display:flex;flex-direction:column;gap:.25rem}.reference-gallery-subtitle{color:#888;font-size:.7rem;margin:0;text-align:center}.empty-gallery-message{color:#888;font-size:.9rem;margin:1rem 0 0;text-align:center}.reference-gallery-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));margin-top:.5rem}.reference-gallery-card{background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:6px;display:flex;flex-direction:column;gap:.5rem;overflow:hidden}.reference-gallery-item .reference-gallery-image{background-color:#0f0f0f;padding-top:75%;position:relative;width:100%}.reference-gallery-item .reference-gallery-image img{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.reference-gallery-item .reference-gallery-actions{padding:.75rem}.reference-gallery-grid .reference-gallery-image{background-color:#0f0f0f;padding-top:75%;position:relative;width:100%}.reference-gallery-grid .reference-gallery-image img{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.reference-gallery-grid .reference-gallery-actions{padding:0 .5rem .75rem}.btn-add-from-gallery{background-color:#2f4f2f;border:1px solid #4caf50;border-radius:4px;color:#cfe8cf;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem .75rem;transition:all .3s;width:100%}.btn-add-from-gallery:hover:not(:disabled){background-color:#4caf501a;border-color:#45a049;color:#a7d7a7}.btn-add-from-gallery:disabled{cursor:not-allowed;opacity:.65}.reference-thumbnail{aspect-ratio:1;border:1px solid #3a3a3a;border-radius:4px;cursor:pointer;overflow:hidden;position:relative;transition:all .3s}.reference-thumbnail:hover{border-color:#4caf50}.reference-thumbnail.selected{border-color:#4caf50;box-shadow:inset 0 0 0 1px #4caf50}.reference-thumbnail.deselected{border-color:#666;opacity:.4}.reference-thumbnail.deselected img{filter:grayscale(80%)}.reference-thumbnail img{height:100%;object-fit:cover;transition:filter .3s;width:100%}.reference-scroll-row{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.25rem}.reference-scroll-row .reference-thumbnail{flex:0 0 72px;min-width:72px}.reference-thumbnail.replicated{border-color:#4caf50}.delete-reference-btn{align-items:center;background:#ff5252e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;opacity:0;position:absolute;right:4px;top:4px;transition:opacity .3s;width:24px}.reference-thumbnail:hover .delete-reference-btn{opacity:1}.delete-reference-btn:hover{background:#ff1744e6}.btn-upload-reference{background-color:#3a3a3a;border:2px dashed #555;border-radius:4px;color:#b0b0b0;cursor:pointer;font-weight:500;padding:.75rem;transition:all .3s;width:100%}.btn-upload-reference:hover{background-color:#4a4a4a;border-color:#4caf50;color:#4caf50}.btn-cancel{background-color:#555;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:.5rem;padding:.5rem 1rem;transition:background-color .3s}.btn-cancel:hover{background-color:#666}.btn-prompt-templates,.prompt-templates-wrapper{position:relative;width:100%}.btn-prompt-templates{background-color:#3a3a3a;border:2px solid #555;border-radius:4px;color:#b0b0b0;cursor:pointer;font-weight:500;padding:.75rem;text-align:left;transition:all .3s}.btn-prompt-templates:after{content:"▼";font-size:.7rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:transform .3s}.prompt-templates-wrapper:has(.prompt-templates-dropdown) .btn-prompt-templates:after{transform:translateY(-50%) rotate(180deg)}.btn-prompt-templates:hover{background-color:#4a4a4a;border-color:#555;color:#e0e0e0}.prompt-templates-dropdown{background-color:#3a3a3a;border:2px solid #555;border-radius:4px;box-shadow:0 4px 12px #00000080;left:0;margin-top:.5rem;max-height:400px;overflow-y:auto;padding:.75rem;position:absolute;right:0;top:100%;z-index:10}.prompt-templates-dropdown::-webkit-scrollbar{width:8px}.prompt-templates-dropdown::-webkit-scrollbar-track{background:#2a2a2a;border-radius:4px}.prompt-templates-dropdown::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.prompt-templates-dropdown::-webkit-scrollbar-thumb:hover{background:#666}.template-item{display:flex;gap:.5rem}.template-item,.template-item:last-of-type{margin-bottom:.5rem}.btn-template{background-color:#2a2a2a;border:1px solid #555;border-radius:4px;color:#b0b0b0;cursor:pointer;flex:1 1;font-size:.875rem;padding:.5rem .75rem;text-align:left;transition:all .3s}.btn-template:hover{background-color:#4a4a4a;border-color:#666;color:#e0e0e0}.btn-delete-template{background:#ff5252e6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:18px;height:auto;transition:background-color .3s;width:30px}.btn-delete-template:hover{background:#ff1744e6}.add-template-form{border-top:1px solid #555;margin-top:.5rem;padding-top:.5rem}.template-input{background-color:#2a2a2a;border:1px solid #555;border-radius:4px;box-sizing:border-box;color:#e0e0e0;font-family:inherit;font-size:.875rem;margin-bottom:.5rem;padding:.75rem;width:100%}.template-input:focus{background-color:#1a1a1a;border-color:#666;outline:none}.template-actions{display:flex;gap:.5rem}.btn-save-template{background-color:#2a2a2a;border:1px solid #555;border-radius:4px;color:#b0b0b0;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.5rem .75rem;transition:all .3s}.btn-save-template:hover{background-color:#4a4a4a;border-color:#666;color:#e0e0e0}.btn-cancel-template{background-color:#2a2a2a;border:1px solid #555;border-radius:4px;color:#b0b0b0;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem .75rem;transition:all .3s}.btn-cancel-template:hover{background-color:#4a4a4a;border-color:#666;color:#e0e0e0}.btn-add-template{background-color:#2a2a2a;border:1px dashed #555;border-radius:4px;color:#b0b0b0;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:.75rem;padding:.75rem .75rem .5rem;transition:all .3s;width:100%}.prompt-templates-dropdown .btn-add-template{background-color:initial;border:none;border-radius:0;border-top:1px solid #555}.btn-add-template:hover{background-color:#4a4a4a;color:#e0e0e0}.uploaded-references{background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;margin-top:.75rem;padding:.75rem}.file-count{color:#b0b0b0;font-size:.875rem;font-weight:500;margin:0 0 .5rem}.uploaded-files-list{display:flex;flex-direction:column;gap:.5rem}.uploaded-file-item{align-items:center;background-color:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;display:flex;justify-content:space-between;padding:.5rem .75rem;transition:all .3s}.uploaded-file-item:hover{background-color:#333;border-color:#4a4a4a}.uploaded-file-item .file-name{color:#e0e0e0;flex:1 1;font-size:.875rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-remove-file{align-items:center;background:#ff5252e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;margin-left:.5rem;min-width:24px;transition:background-color .3s;width:24px}.btn-remove-file:hover{background:#ff1744e6}.button-group{justify-content:center}.btn-option{background-color:#2a2a2a;border:2px solid #3a3a3a;flex:1 1;font-size:.95rem;font-weight:500;min-width:-webkit-fit-content;min-width:fit-content;padding:.75rem 1.25rem}.btn-option:hover{background-color:#3a3a3a;border-color:#4a4a4a}.btn-option.selected{background-color:#4caf50;border-color:#4caf50;color:#fff}.btn-option.selected:hover{background-color:#45a049;border-color:#45a049}@media (max-width:768px){.form-grid{gap:1rem;grid-template-columns:1fr}.generation-menu-wrapper{flex-direction:column}.reference-gallery-container{max-height:none;width:100%}.reference-gallery-list{flex-direction:row;gap:.5rem;overflow-x:auto;overflow-y:hidden}.reference-thumbnail-vertical{flex-shrink:0;min-width:80px;width:80px}}.timer{color:#4a90e2;font-family:Courier New,monospace;font-weight:700}.timer.generating{animation:pulse 1.5s ease-in-out infinite}.timer.completed{color:#666;font-size:.9em}.home-container{margin:0 auto;max-width:1400px;padding:2rem}.home-container h1{color:#e0e0e0;margin:0 0 2rem}.home-content{grid-gap:2rem;display:grid;gap:2rem}.generation-section{max-width:none}.generations-grid{grid-template-columns:repeat(2,1fr)}.generation-image{align-items:center;display:flex;height:420px;justify-content:center}.generation-image img{object-fit:contain}.profile-container{margin:0 auto;max-width:1200px;padding:2rem}.profile-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.profile-header h1{color:#e0e0e0;margin:0}.username{color:#888;margin:.5rem 0 0}.btn-logout{background-color:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:background-color .3s}.btn-logout:hover{background-color:#c0392b}.profile-content h2,.projects-section h2{color:#e0e0e0;margin-bottom:1.5rem}.btn-copy-prompt{background-color:#333;border:1px solid #444;color:#cfcfcf;font-size:.9rem;line-height:1;padding:.35rem .5rem;transition:all .2s}.btn-copy-prompt:hover{background-color:#444;border-color:#555}.cost-breakdown{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.cost-breakdown h3{color:#e0e0e0;font-size:1.25rem;margin:0 0 1.5rem}.cost-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem}.cost-stat-item{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:6px;padding:1rem}.cost-stat-label{color:#888;font-size:.875rem;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.cost-stat-value{color:#66bb6a;font-size:1.5rem;font-weight:600}.cost-breakdown-details{border-top:1px solid #3a3a3a;padding-top:1rem}.cost-breakdown-row{align-items:center;color:#e0e0e0;display:flex;justify-content:space-between;padding:.75rem 0}.cost-breakdown-label{font-size:.95rem}.cost-breakdown-value{color:#66bb6a;font-weight:600}.projects-section{margin-bottom:2.5rem}.projects-grid{gap:1rem}.project-card,.projects-grid{display:flex;flex-direction:column}.project-card{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 4px 15px #00000080;cursor:pointer;overflow:hidden;transition:transform .3s,box-shadow .3s}.project-card:hover{box-shadow:0 6px 25px #000000b3;transform:translateY(-4px)}.project-references-strip{background:#1a1a1a;display:flex;gap:.5rem;overflow-x:auto;padding:.75rem .75rem .25rem}.project-ref-thumb{border:1px solid #3a3a3a;border-radius:6px;flex:0 0 auto;height:72px;overflow:hidden;width:72px}.project-ref-thumb img{height:100%;object-fit:cover;width:100%}.project-image-empty{align-items:center;color:#666;display:flex;font-weight:600;justify-content:center;min-height:72px;width:100%}.project-info{display:flex;flex-direction:column;gap:.6rem;padding:1rem}.project-title-row{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.project-name{color:#e0e0e0;font-size:1rem;line-height:1.2;margin:0}.project-total{color:#66bb6a;font-weight:600}.project-meta{color:#888;display:flex;flex-wrap:wrap;font-size:.85rem;gap:.5rem}.project-meta span{background:#1d3d1d;border:1px solid #284428;border-radius:4px;color:#66bb6a;padding:.25rem .5rem}.project-latest-prompt{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#e0e0e0;display:-webkit-box;font-size:.95rem;line-height:1.4;margin:0;overflow:hidden}.btn-see-more-projects{background:#1f1f1f;border:1px solid #3a3a3a;border-radius:6px;color:#e0e0e0;cursor:pointer;font-weight:600;padding:.75rem 1rem;transition:background-color .2s,border-color .2s;width:100%}.btn-see-more-projects:hover{background:#262626;border-color:#4caf50;color:#4caf50}.modal-details-section{flex:1 1}.modal-detail-label{font-size:.9rem;margin-bottom:.25rem}.modal-meta-tags span{font-size:.75rem;padding:.25rem .5rem}.modal-reference-images{gap:.75rem}.modal-reference-thumbnail{border:1px solid #3a3a3a;border-radius:6px;height:72px;width:72px}.modal-close{font-size:2rem;right:2rem;top:1.5rem}.project-view{margin:0 auto;max-width:1400px;padding:2rem}.project-header{margin-bottom:2rem}.project-header h1{color:#e0e0e0;margin:0}.project-date{color:#888;font-size:.875rem;margin:.5rem 0 0}.project-content{grid-gap:2rem;display:grid;gap:2rem}.generation-section{width:100%}.generations-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.generation-card{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 4px 15px #00000080;overflow:hidden;transition:transform .3s,box-shadow .3s}.generation-card:hover{box-shadow:0 6px 25px #000000b3;transform:translateY(-4px)}.generation-image{background-color:#1a1a1a;cursor:pointer;height:280px;overflow:hidden;width:100%}.generation-image img{height:100%;object-fit:cover;width:100%}.generation-info{padding:1rem}.generation-prompt{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-weight:500;line-height:1.4;margin:0 0 .75rem;overflow:hidden}.generation-meta{margin-bottom:.5rem}.generation-user{color:#888;font-size:.875rem;margin:.5rem 0}.generation-user .username{color:#66bb6a;font-weight:600}.timer-display{align-items:center;display:flex;font-size:1.1rem;justify-content:center}.btn-modal-download{margin-bottom:1.5rem}.btn-modal-library-add{align-items:center;background-color:initial;border:2px solid #4caf50;border-radius:6px;color:#4caf50;cursor:pointer;display:flex;font-size:1rem;justify-content:space-between;margin-bottom:1.5rem;padding:.75rem 1rem;transition:all .3s ease;width:100%}.btn-modal-library-add:hover{background-color:#4caf501a;border-color:#45a049;color:#45a049}.btn-modal-library-remove{margin-bottom:1.5rem}.modal-image{transform-origin:center center;transition:transform .3s ease}.modal-close{background:#0000;border-radius:0;font-size:2.25rem;height:auto;line-height:1;padding:0;transition:color .2s;width:auto}.modal-close:hover{color:#ccc}.modal-prompt-row{gap:.75rem}.modal-prompt-row span{max-height:220px;overflow-y:auto;scrollbar-color:#555 #0000;scrollbar-width:thin}.modal-prompt-row span::-webkit-scrollbar{width:6px}.modal-prompt-row span::-webkit-scrollbar-track{background:#0000}.modal-prompt-row span::-webkit-scrollbar-thumb{background-color:#555;border-radius:999px}.modal-prompt-row span::-webkit-scrollbar-thumb:hover{background-color:#666}.btn-copy-prompt{align-items:center;background:#1f1f1f;border:1px solid #3a3a3a;border-radius:4px;color:#66bb6a;display:inline-flex;height:28px;justify-content:center;padding:0;transition:background-color .3s,border-color .3s;width:28px}.btn-copy-prompt:hover{background-color:#2a2a2a;border-color:#4caf50}.modal-reference-thumbnail{cursor:pointer;transition:border-color .3s,transform .3s}.modal-reference-thumbnail:hover{border-color:#66bb6a;transform:scale(1.05)}.placeholder-card{position:relative}.placeholder-shimmer{animation:shimmer 2s ease-in-out infinite;background:linear-gradient(90deg,#1a1a1a,#2a2a2a 50%,#1a1a1a);background-size:200% 100%;overflow:hidden;position:relative}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.shimmer-content{align-items:center;display:flex;flex-direction:column;gap:.75rem;height:100%;justify-content:center;position:relative;width:100%}.generating-text{animation:pulse 1.5s ease-in-out infinite;color:#888;font-size:1rem;font-weight:500}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.retrying-card{border:1px solid #ff9800}.retrying-card .placeholder-shimmer{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#2a1a0a,#3a2a1a 50%,#2a1a0a);background-size:200% 100%}.retry-status-text{color:#ff9800;font-size:1.1rem;font-weight:600}.retry-attempt-text{animation:pulse 1s ease-in-out infinite;color:#ffb74d;font-size:.95rem;font-weight:500}.error-card{border:1px solid #ff5252}.error-content{align-items:center;background-color:#2a1a1a;display:flex;flex-direction:column;gap:.5rem;justify-content:center}.error-icon{font-size:3rem}.error-text{color:#ff5252;font-size:1.25rem;font-weight:600}.error-message-text{background-color:#ff52521a;border:1px solid #ff52524d;border-radius:4px;color:#ff5252;font-size:.875rem;font-weight:500;margin:.5rem 0;padding:.5rem}@media (max-width:768px){.modal-content{flex-direction:column;max-height:95vh}.modal-details-section{flex:0 0 auto;max-height:40vh}.generations-grid{grid-template-columns:1fr}}.failed-generations-container{margin:0 auto;max-width:1400px;padding:2rem}.failed-generations-container h1{color:#e0e0e0;margin:0 0 2rem}.failed-generations-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.failed-generation-card{background:#2a2a2a;border:2px solid #ff5252;border-radius:8px;box-shadow:0 4px 15px #00000080;display:flex;flex-direction:column;overflow:hidden}.failed-generation-icon{align-items:center;background:linear-gradient(135deg,#3a1a1a,#2a2a2a);border-bottom:2px solid #ff5252;display:flex;flex-direction:column;gap:.5rem;justify-content:center;padding:3rem 1rem}.error-icon{color:#ff5252;font-size:4rem}.failed-label{color:#ff5252;font-size:1.2rem;font-weight:600;letter-spacing:1px;text-transform:uppercase}.failed-generation-info{padding:1rem}.generation-prompt-row{align-items:flex-start;display:flex;gap:.5rem;margin-bottom:.75rem}.generation-prompt{color:#e0e0e0;flex:1 1;line-height:1.5;margin:0;word-break:break-word}.btn-copy-prompt{background:none;border:none;color:#888;cursor:pointer;flex-shrink:0;font-size:1.2rem;padding:.25rem;transition:color .3s}.btn-copy-prompt:hover{color:#66bb6a}.generation-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.generation-meta span{background-color:#1d3d1d;border-radius:4px;color:#66bb6a;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.error-details{background:#3a1a1a;border-left:3px solid #ff5252;border-radius:4px;color:#ff8a80;font-size:.875rem;line-height:1.5;margin:.75rem 0;padding:.75rem}.error-details strong{color:#ff5252;display:block;margin-bottom:.25rem}.generation-cost{color:#66bb6a;font-size:.875rem;font-weight:600;margin:.5rem 0}.generation-project,.generation-time{color:#888;font-size:.875rem;margin:.5rem 0}.generation-date{color:#666;font-size:.875rem;margin:.5rem 0}.btn-delete-gen{background-color:#ff5252;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;margin-top:.5rem;padding:.5rem;transition:background-color .3s;width:100%}.btn-delete-gen:hover{background-color:#ff1744}@media (max-width:768px){.failed-generations-grid{grid-template-columns:1fr}}.prompt-library-container{margin:0 auto;max-width:1400px;padding:2rem}.prompt-library-header h1{color:#e0e0e0;margin:0 0 .25rem}.prompt-library-subtitle{color:#9a9a9a;font-size:1rem;margin:0 0 1.5rem}.prompt-library-list{display:flex;flex-direction:column;gap:.75rem}.prompt-library-row{grid-gap:.75rem;align-items:center;background:#252525;border:1px solid #333;border-radius:8px;cursor:pointer;display:grid;gap:.75rem;grid-template-columns:5fr 1fr 1fr 2fr 1.5fr;padding:.75rem 1rem;transition:border-color .2s,transform .2s}.prompt-library-row:hover{border-color:#4caf50;transform:translateY(-1px)}.prompt-col{align-items:center;display:flex;gap:.5rem}.prompt-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#e0e0e0;display:-webkit-box;font-weight:500;line-height:1.4;max-height:3.6em;overflow:hidden}.prompt-thumb{height:64px}.prompt-thumb img{border:1px solid #3a3a3a;border-radius:6px;height:100%;object-fit:cover;width:100%}.prompt-copy,.prompt-replicate{justify-content:center}.prompt-references{overflow:hidden}.prompt-ref-scroll{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem}.prompt-ref-thumb{border:1px solid #3a3a3a;border-radius:6px;flex:0 0 auto;height:48px;overflow:hidden;width:48px}.prompt-ref-thumb img{height:100%;object-fit:cover;width:100%}.no-refs{color:#666;font-size:.875rem}.btn-copy-row,.btn-replicate{background:#0000;border:1px solid #4caf50;border-radius:6px;color:#e0e0e0;cursor:pointer;font-weight:600;padding:.45rem .9rem;transition:all .2s}.btn-copy-row:hover,.btn-replicate:hover{background-color:#4caf501a;border-color:#45a049;color:#a7d7a7}.btn-show-more-prompts{background:#0000;border:1px solid #4caf50;border-radius:6px;color:#e0e0e0;cursor:pointer;display:block;font-weight:600;margin:1rem auto 0;padding:.6rem 1.4rem;transition:all .2s}.btn-show-more-prompts:hover{background-color:#4caf501a;border-color:#45a049;color:#a7d7a7}.modal-overlay{background:#000c}.modal-content{background:#1a1a1a;box-shadow:0 10px 40px #000c;display:grid;grid-template-columns:1.5fr 1fr;position:relative;width:min(1200px,95vw)}.modal-image-section{background:#0f0f0f;position:relative}.modal-image{cursor:zoom-in;max-height:80vh;max-width:100%;transition:transform .2s ease-out}.modal-image.zoomed{cursor:zoom-out}.modal-details-section{background:#161616;border-left:1px solid #222;padding:1.5rem}.modal-close{background:#0009;font-size:20px;height:32px;right:10px;top:10px;width:32px;z-index:10}.modal-detail-group{margin-bottom:1rem}.modal-detail-label{font-size:.95rem;margin-bottom:.35rem}.modal-detail-value{font-weight:500}.modal-prompt-row{align-items:flex-start;display:flex;gap:.5rem}.modal-prompt-row span{background:#0f0f0f;border:1px solid #333;border-radius:6px;flex:1 1;max-height:160px;overflow:auto;padding:.6rem .75rem}.modal-reference-images{display:flex;flex-wrap:wrap;gap:.5rem}.modal-reference-thumbnail{background-color:#1a1a1a;border:2px solid #3a3a3a;border-radius:4px;height:60px;overflow:hidden;width:60px}.modal-reference-thumbnail img{height:100%;object-fit:cover;width:100%}.btn-modal-library-remove{align-items:center;background-color:initial;border:2px solid #ff9800;border-radius:6px;color:#ff9800;cursor:pointer;display:flex;font-size:1rem;justify-content:space-between;margin-top:1.5rem;padding:.75rem 1rem;transition:all .3s ease;width:100%}.btn-modal-library-remove:hover{background-color:#ff98001a;border-color:#f57c00;color:#f57c00}.btn-icon{display:inline-flex;font-size:1.2rem}@media (max-width:960px){.prompt-library-row{grid-template-columns:1fr}.prompt-thumb{height:180px}.prompt-copy,.prompt-replicate{justify-content:flex-start}}.downscaler-container{margin:0 auto;max-width:1400px;padding:2rem}.downscaler-container h1{color:#e0e0e0;margin:0 0 2rem}.downscaler-content{grid-gap:2rem;display:grid;gap:2rem}.downscaler-form-section{display:flex;flex-direction:column;gap:1.5rem}.upload-zone{align-items:center;background-color:#1a1a1a;border:2px dashed #3a3a3a;border-radius:8px;cursor:pointer;display:flex;justify-content:center;min-height:300px;transition:border-color .3s,background-color .3s;width:100%}.upload-zone:hover{background-color:#222;border-color:#4caf50}.upload-zone.has-image{border-color:#4caf50;border-style:solid;cursor:default}.upload-placeholder{color:#666;text-align:center}.upload-icon{color:#4caf50;font-size:3rem;margin-bottom:1rem}.upload-placeholder p{font-size:1rem;margin:0}.preview-container{align-items:center;display:flex;height:100%;justify-content:center;padding:1rem;position:relative;width:100%}.preview-image{border-radius:4px;max-height:400px;max-width:100%;object-fit:contain}.btn-clear-preview{align-items:center;background:#ff5252;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;height:32px;justify-content:center;position:absolute;right:.5rem;top:.5rem;transition:background-color .3s;width:32px}.btn-clear-preview:hover{background-color:#ff1744}.downscaler-settings{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;padding:1.5rem}.setting-group{margin-bottom:1.5rem}.setting-group:last-child{margin-bottom:0}.setting-group label{color:#888;display:block;font-size:.875rem;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.button-group{display:flex;flex-wrap:wrap;gap:.5rem}.btn-option{background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;color:#b0b0b0;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .3s}.btn-option:hover{background-color:#333;color:#e0e0e0}.btn-option.active{border-color:#4caf50}.btn-option.active,.btn-process{background-color:#4caf50;color:#fff}.btn-process{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:1rem;transition:background-color .3s;width:100%}.btn-process:hover:not(:disabled){background-color:#45a049}.btn-process:disabled{background-color:#333;color:#666;cursor:not-allowed}.history-section h2{color:#e0e0e0;margin-bottom:1.5rem}.empty-message{color:#888;padding:3rem;text-align:center}.downscaler-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.downscaler-card{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 4px 15px #00000080;overflow:hidden;transition:transform .3s,box-shadow .3s}.downscaler-card:hover{box-shadow:0 6px 25px #000000b3;transform:translateY(-4px)}.downscaler-image{align-items:center;background-color:#1a1a1a;cursor:pointer;display:flex;height:350px;justify-content:center;overflow:hidden;width:100%}.downscaler-image img{height:100%;object-fit:contain;width:100%}.downscaler-info{padding:1rem}.downscaler-filename{color:#e0e0e0;font-weight:500;line-height:1.4;margin:0 0 .75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.downscaler-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.downscaler-meta span{background-color:#1d3d1d;border-radius:4px;color:#66bb6a;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.downscaler-user{color:#888;font-size:.875rem;margin:.5rem 0}.downscaler-user .username{color:#66bb6a;font-weight:600}.downscaler-date{color:#666;font-size:.875rem;margin:.5rem 0}.modal-overlay{align-items:center;background-color:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;display:flex;gap:2rem;max-height:90vh;max-width:1200px;overflow:hidden;width:100%}.modal-image-section{align-items:center;background-color:#1a1a1a;display:flex;flex:1 1;justify-content:center;min-height:400px;overflow:hidden;padding:0}.modal-image{height:100%;object-fit:contain;width:100%}.modal-details-section{display:flex;flex:0 0 400px;flex-direction:column;gap:1.5rem;overflow-y:auto;padding:2rem}.modal-close{align-items:center;background:#ff5252;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:background-color .3s;width:40px;z-index:1001}.modal-close:hover{background-color:#ff1744}.modal-detail-group{border-bottom:1px solid #3a3a3a;padding-bottom:1rem}.modal-detail-group:last-child{border-bottom:none}.modal-detail-label{color:#888;font-size:.875rem;font-weight:500;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.modal-detail-value{color:#e0e0e0;font-size:1rem;line-height:1.5}.modal-meta-tags{display:flex;flex-wrap:wrap;gap:.5rem}.modal-meta-tags span{background-color:#1d3d1d;border-radius:4px;color:#66bb6a;font-size:.875rem;font-weight:500;padding:.5rem .75rem}.modal-username{color:#66bb6a;font-weight:600}.btn-modal-download{align-items:center;background-color:initial;border:2px solid #4caf50;border-radius:6px;color:#4caf50;cursor:pointer;display:flex;font-size:1rem;font-weight:600;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem;transition:all .3s;width:100%}.btn-modal-download:hover{background-color:#4caf501a;border-color:#45a049;color:#45a049}.btn-modal-delete{align-items:center;background-color:initial;border:2px solid #666;border-radius:6px;color:#888;cursor:pointer;display:flex;font-size:1rem;font-weight:600;justify-content:space-between;margin-top:.5rem;padding:.75rem 1rem;transition:all .3s;width:100%}.btn-modal-delete:hover{background-color:#8888881a;border-color:#999;color:#999}.btn-icon-text{align-items:center;display:inline-flex;font-size:1.2rem}.load-more-sentinel{height:1px;width:100%}.btn-show-more{background-color:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;display:block;font-size:1rem;font-weight:600;margin:2rem auto 0;max-width:300px;padding:.875rem 1.5rem;transition:background-color .3s,transform .2s;width:100%}.btn-show-more:hover{background-color:#45a049;transform:translateY(-2px)}@media (max-width:768px){.modal-content{flex-direction:column;max-height:95vh}.modal-details-section{flex:0 0 auto;max-height:40vh}.downscaler-grid{grid-template-columns:1fr}}.sidebar{background-color:#222;border-right:1px solid #333;color:#e0e0e0;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:250px;z-index:100}.sidebar-header{align-items:center;border-bottom:1px solid #333;display:flex;justify-content:space-between;padding:1.5rem 1rem}.sidebar-header h3{color:#e0e0e0;font-size:1.25rem;margin:0}.profile-username{background:none;border:none;color:#888;cursor:pointer;font-size:1.3rem;font-weight:600;max-width:120px;overflow:hidden;padding:0;text-overflow:ellipsis;transition:color .2s ease;white-space:nowrap}.profile-username:hover{color:#e0e0e0}.profile-username.active{color:#4caf50}.btn-icon{align-items:center;background:none;border:none;border-radius:4px;color:#e0e0e0;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;transition:background-color .3s;width:32px}.btn-icon:hover,.new-project-form{background-color:#2a2a2a}.new-project-form{border-bottom:1px solid #333;padding:1rem}.new-project-form input{background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;color:#e0e0e0;margin-bottom:.5rem;padding:.5rem;width:100%}.new-project-form input:focus{background-color:#222;border-color:#4caf50;outline:none}.form-actions{display:flex;gap:.5rem}.btn-sm{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:.875rem;padding:.4rem .8rem}.btn-primary{background-color:#4caf50;color:#fff}.btn-primary:hover{background-color:#45a049}.btn-secondary{background-color:#555;color:#fff}.btn-secondary:hover{background-color:#666}.sidebar-menu{border-bottom:1px solid #333;padding:1rem 0}.sidebar-menu.downscaler-section{padding:.5rem 0}.menu-item{color:#b0b0b0;cursor:pointer;padding:.75rem 1rem;transition:background-color .3s}.menu-item:hover{background-color:#2a2a2a;color:#e0e0e0}.menu-item.active{background-color:#4caf50;color:#fff;font-weight:600}.projects-list{flex:1 1;overflow-y:auto;padding:1rem 0}.projects-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:0 1rem}.projects-list h4{color:#e0e0e0;font-size:.875rem;margin:0;text-transform:uppercase}.project-item{align-items:center;color:#b0b0b0;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;transition:background-color .3s}.project-item:hover{background-color:#2a2a2a;color:#e0e0e0}.project-item.active{background-color:#4caf50;color:#fff}.project-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-delete{align-items:center;background:none;border:none;border-radius:4px;color:#e74c3c;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;opacity:.7;padding:0;transition:opacity .3s;width:24px}.btn-delete:hover{background-color:#e74c3c33;opacity:1}.empty-message{color:#777;font-size:.875rem;font-style:italic;padding:0 1rem}.online-users-container{background-color:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 4px 12px #0000004d;max-width:250px;min-width:180px;padding:8px 12px;position:fixed;right:16px;top:16px;z-index:1000}.online-users-list{display:flex;flex-direction:column;gap:8px}.online-user-item{align-items:center;display:flex;gap:8px;padding:4px 0}.online-dot{background-color:#4caf50;border-radius:50%;box-shadow:0 0 6px #4caf5080;flex-shrink:0;height:8px;width:8px}.online-username{color:#e0e0e0;flex:1 1;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.online-status{color:#4caf50;font-size:12px;font-weight:500}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app-layout,body{background-color:#1a1a1a}.app-layout{display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:250px;overflow-y:auto}.loading,.main-content{background-color:#1a1a1a}.loading{align-items:center;color:#b0b0b0;display:flex;font-size:1.25rem;justify-content:center;min-height:100vh}
/*# sourceMappingURL=main.b6d055d4.css.map*/