*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:#333;background:#0e0e0e;min-height:100vh}#root{min-height:100vh;padding-top:80px}.app-wrapper{display:flex;align-items:center;justify-content:center;padding:20px;min-height:calc(100vh - 80px)}.top-nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:15px 30px;background:#111827f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(75,85,99,.3);box-shadow:0 1px 3px #0000001a}.nav-left{display:flex;align-items:center;justify-self:start}.nav-center{display:flex;align-items:center;justify-self:center}.nav-right{display:flex;align-items:center;justify-self:end}.nav-left h1{margin:0;color:#fff;font-size:1.5rem;cursor:pointer;transition:color .2s;font-weight:600}.nav-left h1:hover{color:#a855f7}.main-nav{display:flex;align-items:center;gap:15px}.nav-button{padding:8px 16px;background:transparent;color:#9ca3af;border:1px solid #4b5563;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.nav-button:hover{background:#9ca3af1a;color:#d1d5db;border-color:#6b7280}.logout-button{background:#dc2626;color:#fff;border-color:#dc2626}.logout-button:hover{background:#b91c1c;border-color:#b91c1c}.pricing-button{background:transparent;color:#9ca3af;border:2px solid #4b5563}.pricing-button:hover{background:#10b9811a;color:#10b981;border-color:#10b981}.lab-button{background:transparent;color:#a78bfa;border:2px solid #8b5cf6}.lab-button:hover{background:#8b5cf626;color:#c4b5fd;border-color:#a78bfa}.credits-display{display:flex;align-items:center;gap:6px;background:#374151cc;padding:8px 16px;border-radius:20px;border:1px solid #4b5563;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.credits-count{font-weight:700;color:#10b981;font-size:18px}.credits-label{color:#9ca3af;font-size:14px}.user-info{display:flex;align-items:center;gap:15px}.user-email{color:#9ca3af;font-size:14px;font-weight:500}.profile-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#374151;color:#9ca3af;cursor:pointer;transition:all .2s;border:2px solid #4b5563}.profile-icon:hover{background:#4b5563;color:#10b981;border-color:#10b981}.profile-icon svg{width:20px;height:20px}@media (max-width: 768px){.top-nav{grid-template-columns:1fr;gap:15px;padding:15px 20px}.nav-left,.nav-center,.nav-right{justify-self:center}.nav-left h1{font-size:1.25rem}.user-info{flex-direction:column;gap:10px;text-align:center}.credits-display{margin-bottom:10px}}.profile-container{max-width:800px;margin:0 auto;padding:40px 20px}.profile-header{display:flex;align-items:center;gap:20px;margin-bottom:40px;padding-bottom:20px;border-bottom:2px solid #4b5563}.profile-avatar{width:80px;height:80px;border-radius:50%;background:#374151;color:#10b981;display:flex;align-items:center;justify-content:center;border:3px solid #10b981}.profile-header h1{color:#fff;font-size:2.5rem;margin:0;font-weight:600}.profile-error{text-align:center;padding:60px 20px;background:#ef44441a;border:2px solid #ef4444;border-radius:12px}.profile-error h2{color:#ef4444;margin-bottom:10px}.profile-error p{color:#9ca3af}.profile-error-message{background:#ef44441a;color:#ef4444;padding:12px 16px;border-radius:8px;margin-bottom:20px;border:1px solid #ef4444}.profile-sections{display:flex;flex-direction:column;gap:32px}.profile-section{background:#111827cc;border:1px solid #4b5563;border-radius:12px;padding:24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.profile-section h2{color:#fff;font-size:1.5rem;margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid #4b5563;font-weight:600}.profile-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.profile-info-item{display:flex;flex-direction:column;gap:6px}.profile-info-item label{color:#9ca3af;font-size:14px;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.profile-info-item span{color:#fff;font-size:16px;font-weight:500}.credits-info{display:flex;flex-direction:column;gap:24px}.credits-balance{display:flex;justify-content:center}.credits-display-simple{display:flex;align-items:center;gap:12px}.credits-count-large{font-weight:700;color:#10b981;font-size:2.5rem}.credits-display-simple .credits-label{color:#9ca3af;font-size:16px;font-weight:500}.credits-description{text-align:center;padding:16px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:8px}.credits-description p{color:#9ca3af;margin:0;font-size:14px;line-height:1.5}.subscription-info{display:flex;flex-direction:column;gap:24px}.current-plan h3{color:#fff;font-size:1.2rem;margin:0 0 16px;font-weight:600}.plan-display{background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:8px}.plan-name{color:#10b981;font-size:1.5rem;font-weight:700;display:flex;align-items:center;gap:12px}.status-badge{font-size:.75rem;padding:4px 12px;border-radius:12px;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.status-badge.active{background:#10b98133;color:#10b981;border:1px solid #10b981}.status-badge.trialing{background:#3b82f633;color:#3b82f6;border:1px solid #3b82f6}.status-badge.canceled{background:#ef444433;color:#ef4444;border:1px solid #ef4444}.plan-description{color:#9ca3af;font-size:14px;line-height:1.5}.plan-renewal{display:block;color:#6b7280;font-size:13px;margin-top:8px;font-style:italic}.subscription-actions{display:flex;justify-content:center}.upgrade-button{padding:12px 24px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.upgrade-button:hover{background:#059669;transform:translateY(-1px)}.manage-subscription-button{padding:12px 24px;background:transparent;color:#9ca3af;border:2px solid #6b7280;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.manage-subscription-button:hover{background:#9ca3af1a;color:#d1d5db;border-color:#9ca3af}.billing-loading{display:flex;align-items:center;justify-content:center;gap:12px;color:#9ca3af;padding:40px 20px}.loader-small{border:2px solid #4b5563;border-top:2px solid #10b981;border-radius:50%;width:20px;height:20px;animation:spin 1s linear infinite}.account-actions{display:flex;justify-content:flex-start}.sign-out-button{padding:12px 24px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.sign-out-button:hover{background:#dc2626;transform:translateY(-1px)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.profile-container{padding:20px 15px}.profile-header{flex-direction:column;text-align:center;gap:15px}.profile-avatar{width:60px;height:60px}.profile-header h1{font-size:2rem}.profile-info-grid{grid-template-columns:1fr}.credits-count-large{font-size:2rem}.profile-sections{gap:24px}.profile-section{padding:20px}}.pricing-container{padding:40px 20px;max-width:1200px;margin:0 auto}.pricing-header-section{text-align:center;margin-bottom:50px}.pricing-container h2{font-size:2.5rem;margin-bottom:15px;color:#fff;font-weight:600}.pricing-subtitle{font-size:1.1rem;color:#9ca3af;margin-bottom:40px;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.5}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-bottom:50px;max-width:1400px;margin-left:auto;margin-right:auto}.pricing-card{background:#111827cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 4px 20px #0000004d;padding:30px;position:relative;transition:all .3s ease;border:2px solid #374151}.pricing-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #0006;border-color:#10b981}.pricing-card.popular{border-color:#10b981;transform:scale(1.02);background:#10b9810d}.pricing-card.popular:hover{transform:scale(1.02) translateY(-5px)}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:6px 20px;border-radius:20px;font-size:.85rem;font-weight:600;white-space:nowrap}.pricing-header{text-align:center;margin-bottom:30px}.pricing-header h3{font-size:1.5rem;margin-bottom:15px;color:#fff;font-weight:600}.price{display:flex;align-items:center;justify-content:center;gap:2px}.currency{font-size:1.2rem;color:#9ca3af;margin-top:-10px}.amount{font-size:3rem;font-weight:700;color:#10b981}.period{color:#9ca3af;margin-left:5px;font-size:1rem}.pricing-content{margin-bottom:30px}.description{text-align:center;color:#9ca3af;margin-bottom:25px;font-size:1rem;line-height:1.5}.credits-info{text-align:center;margin-bottom:25px;padding:20px;background:#10b9811a;border-radius:12px;border:1px solid rgba(16,185,129,.3)}.credits-amount{font-size:1.4rem;font-weight:700;color:#10b981;margin-bottom:5px}.credits-note{font-size:.9rem;color:#9ca3af;margin-bottom:5px}.credits-value{font-size:.85rem;color:#10b981;font-weight:500}.features-list{list-style:none;padding:0;margin:0}.features-list li{color:#d1d5db;position:relative;padding:10px 0 10px 25px;font-size:.95rem;line-height:1.4}.features-list li:before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700;font-size:1.1rem}.subscribe-button{width:100%;padding:15px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.subscribe-button:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 15px #10b9814d}.subscribe-button:active{transform:translateY(0)}.subscribe-button:disabled{background:#6b7280;cursor:not-allowed;transform:none;box-shadow:none}.pricing-footer{margin-top:60px;padding-top:40px;border-top:1px solid #374151}.pricing-info h3{text-align:center;color:#fff;font-size:1.8rem;margin-bottom:30px;font-weight:600}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px}.info-item{text-align:center;padding:20px}.info-icon{font-size:2.5rem;margin-bottom:15px}.info-item h4{color:#fff;font-size:1.2rem;margin-bottom:10px;font-weight:600}.info-item p{color:#9ca3af;font-size:.95rem;line-height:1.4}.back-to-main{text-align:center;margin-top:40px;padding-top:30px;border-top:1px solid #374151}.back-button{padding:12px 24px;background:transparent;color:#9ca3af;border:2px solid #4b5563;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#9ca3af1a;color:#d1d5db;border-color:#6b7280}.loading,.error{text-align:center;padding:60px 20px;font-size:1.1rem}.loading{color:#9ca3af}.error{color:#ef4444}@media (max-width: 1200px){.pricing-grid{grid-template-columns:repeat(3,1fr);gap:20px}}@media (max-width: 968px){.pricing-grid{grid-template-columns:1fr;gap:25px}}@media (max-width: 768px){.pricing-container{padding:30px 15px}.pricing-grid{grid-template-columns:1fr;gap:25px}.pricing-card.popular{transform:none}.pricing-card.popular:hover{transform:translateY(-5px)}.pricing-container h2{font-size:2rem}.amount{font-size:2.5rem}.info-grid{grid-template-columns:1fr;gap:25px}.pricing-card{padding:25px}}@media (max-width: 480px){.pricing-card{padding:20px}.amount{font-size:2.2rem}.pricing-container h2{font-size:1.8rem}}.lab-container{background:#1d1d1d;border:1px solid #000000;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;margin:20px;max-width:1200px}.lab-header{text-align:center;margin-bottom:2rem}.lab-title{color:#8b5cf6;margin-bottom:10px;font-size:2.5rem}.lab-subtitle{color:#9ca3af;font-size:1rem}.lab-hint-section{margin-bottom:1.5rem;padding:1.5rem;background:#2a2a2a;border-radius:12px;border:1px solid #374151}.lab-hint-label{display:block;margin-bottom:.75rem;font-weight:600;color:#8b5cf6;font-size:1rem}.lab-hint-textarea{width:100%;min-height:100px;padding:1rem;border-radius:8px;border:1px solid #4b5563;background:#1d1d1d;color:#d1d5db;resize:vertical;font-family:inherit;font-size:.9rem;transition:border-color .3s}.lab-hint-textarea:focus{outline:none;border-color:#8b5cf6}.lab-hint-textarea::placeholder{color:#6b7280}.lab-hint-textarea:disabled{opacity:.6;cursor:not-allowed}.lab-hint-help{font-size:.85rem;color:#6b7280;margin-top:.75rem}.lab-preselect-section{margin-bottom:1.5rem;padding:1.5rem;background:#2a2a2a;border-radius:12px;border:1px solid #374151}.lab-preselect-row{display:flex;gap:1.5rem;flex-wrap:wrap}.lab-preselect-field{flex:1;min-width:200px}.lab-preselect-label{display:block;margin-bottom:.5rem;font-weight:600;color:#8b5cf6;font-size:.9rem}.lab-preselect-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border-radius:8px;border:1px solid #4b5563;background:#1d1d1d;color:#d1d5db;font-family:inherit;font-size:.9rem;cursor:pointer;transition:border-color .3s;-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' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.lab-preselect-select:focus{outline:none;border-color:#8b5cf6}.lab-preselect-select:disabled{opacity:.6;cursor:not-allowed}.lab-preselect-help{font-size:.85rem;color:#6b7280;margin-top:.75rem}.lab-dropzone{border:2px dashed #8b5cf6;border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#2d2d2d;margin:20px 0}.lab-dropzone:hover{border-color:#a78bfa;background:#3d3d3d}.lab-dropzone.active{border-color:#a78bfa;background:#3d3d3d;transform:scale(1.02)}.lab-dropzone.uploading{pointer-events:none;opacity:.9;border-style:solid}.lab-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.lab-modal{background:#1d1d1d;border:1px solid #374151;border-radius:16px;padding:2rem;max-width:600px;width:90%;max-height:80vh;overflow:auto;box-shadow:0 25px 50px -12px #00000080}.lab-modal-title{margin:0 0 1.5rem;font-size:1.5rem;font-weight:600;color:#d1d5db}.lab-cluster-concept{background:#2a2a2a;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;border:1px solid #374151}.lab-cluster-concept strong{color:#8b5cf6}.lab-cluster-concept p{margin:.5rem 0 0;color:#9ca3af}.lab-angles-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;color:#d1d5db}.lab-deselect-btn{padding:.25rem .75rem;font-size:.75rem;background:#374151;border:1px solid #4b5563;border-radius:4px;cursor:pointer;color:#9ca3af;transition:all .2s}.lab-deselect-btn:hover{background:#4b5563;color:#d1d5db}.lab-custom-angles{margin-bottom:1.5rem;color:#d1d5db}.lab-custom-angles strong{display:block;margin-bottom:.75rem}.lab-custom-input-row{display:flex;gap:.5rem}.lab-custom-input{flex:1;padding:.75rem;border-radius:6px;border:1px solid #4b5563;background:#2a2a2a;color:#d1d5db;font-size:.9rem;transition:border-color .3s}.lab-custom-input:focus{outline:none;border-color:#8b5cf6}.lab-custom-input::placeholder{color:#6b7280}.lab-add-btn{padding:.75rem 1.25rem;background:#8b5cf6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.lab-add-btn:hover:not(.disabled){background:#7c3aed}.lab-add-btn.disabled{background:#4b5563;cursor:not-allowed}.lab-custom-tags{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.lab-custom-tag{background:#8b5cf633;color:#a78bfa;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.lab-tag-remove{background:none;border:none;cursor:pointer;color:#9ca3af;padding:0;font-size:1.1rem;line-height:1;transition:color .2s}.lab-tag-remove:hover{color:#ef4444}.lab-continue-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.lab-continue-btn:hover:not(.disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.lab-continue-btn.disabled{background:#4b5563;cursor:not-allowed}.lab-modal-footer{margin:1rem 0 0;font-size:.85rem;color:#6b7280;text-align:center}.lab-intent{background:#8b5cf61a;padding:.5rem;border-radius:4px;margin-top:.5rem}.lab-intent strong{color:#a78bfa}.lab-grammar-badge{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0}.grammar-tag,.shot-tag,.style-tag{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.grammar-tag{color:#fff}.grammar-tag.secondary{opacity:.6;font-size:.65rem;margin-left:.25rem}.stage-card-badge.secondary{opacity:.7;font-size:.6rem}.grammar-vector-display{display:flex;flex-direction:column;gap:.25rem}.grammar-weight-row{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.grammar-weight-label{width:75px;font-size:.65rem;font-weight:600;text-transform:uppercase;padding:.1rem .3rem;border-radius:3px;color:#fff;text-align:center}.grammar-weight-label.grammar-people{background:#3b82f6}.grammar-weight-label.grammar-animals{background:#10b981}.grammar-weight-label.grammar-environment{background:#059669}.grammar-weight-label.grammar-texture{background:#8b5cf6}.grammar-weight-label.grammar-object{background:#f59e0b}.grammar-weight-label.grammar-abstract{background:#ec4899}.grammar-weight-label.grammar-concept{background:#6366f1}.grammar-weight-bar-container{flex:1;height:8px;background:#374151;border-radius:4px;overflow:hidden}.grammar-weight-bar{height:100%;border-radius:4px;transition:width .3s ease}.grammar-weight-bar.grammar-people{background:#3b82f6}.grammar-weight-bar.grammar-animals{background:#10b981}.grammar-weight-bar.grammar-environment{background:#059669}.grammar-weight-bar.grammar-texture{background:#8b5cf6}.grammar-weight-bar.grammar-object{background:#f59e0b}.grammar-weight-bar.grammar-abstract{background:#ec4899}.grammar-weight-bar.grammar-concept{background:#6366f1}.grammar-weight-value{width:35px;text-align:right;color:#9ca3af;font-family:monospace}.lab-grammar-weights-section{background:#2a2a2a;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #374151}.lab-grammar-weights-section>strong{color:#d1d5db;display:block;margin-bottom:.75rem}.grammar-weights-list{display:flex;flex-direction:column;gap:.5rem}.grammar-weight-item{display:flex;align-items:center;gap:.5rem}.grammar-weight-badge{width:90px;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;color:#fff;text-align:center;text-transform:uppercase}.grammar-weight-badge.grammar-people{background:#3b82f6}.grammar-weight-badge.grammar-animals{background:#10b981}.grammar-weight-badge.grammar-environment{background:#059669}.grammar-weight-badge.grammar-texture{background:#8b5cf6}.grammar-weight-badge.grammar-object{background:#f59e0b}.grammar-weight-badge.grammar-abstract{background:#ec4899}.grammar-weight-badge.grammar-concept{background:#6366f1}.grammar-count{width:30px;font-size:.75rem;color:#6b7280;text-align:center}.grammar-weight-bar-bg{flex:1;height:10px;background:#374151;border-radius:5px;overflow:hidden}.grammar-weight-bar-fill{height:100%;border-radius:5px;transition:width .3s ease}.grammar-weight-bar-fill.grammar-people{background:#3b82f6}.grammar-weight-bar-fill.grammar-animals{background:#10b981}.grammar-weight-bar-fill.grammar-environment{background:#059669}.grammar-weight-bar-fill.grammar-texture{background:#8b5cf6}.grammar-weight-bar-fill.grammar-object{background:#f59e0b}.grammar-weight-bar-fill.grammar-abstract{background:#ec4899}.grammar-weight-bar-fill.grammar-concept{background:#6366f1}.grammar-weight-score{width:40px;text-align:right;font-size:.8rem;font-family:monospace;color:#9ca3af}.lab-image-vectors-section{background:#2a2a2a;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #374151}.lab-image-vectors-section>strong{color:#d1d5db;display:block;margin-bottom:.75rem}.image-vectors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;max-height:300px;overflow-y:auto;padding-right:.5rem}.image-vector-card{background:#1d1d1d;border-radius:8px;padding:.6rem;border:1px solid #374151}.image-vector-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.5rem;flex-wrap:wrap}.image-vector-filename{font-size:.7rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:60px}.image-vector-primary,.image-vector-secondary{padding:.15rem .4rem;border-radius:3px;font-size:.6rem;font-weight:600;color:#fff;text-transform:uppercase}.image-vector-secondary{opacity:.6}.image-vector-primary.grammar-people,.image-vector-secondary.grammar-people{background:#3b82f6}.image-vector-primary.grammar-animals,.image-vector-secondary.grammar-animals{background:#10b981}.image-vector-primary.grammar-environment,.image-vector-secondary.grammar-environment{background:#059669}.image-vector-primary.grammar-texture,.image-vector-secondary.grammar-texture{background:#8b5cf6}.image-vector-primary.grammar-object,.image-vector-secondary.grammar-object{background:#f59e0b}.image-vector-primary.grammar-abstract,.image-vector-secondary.grammar-abstract{background:#ec4899}.image-vector-primary.grammar-concept,.image-vector-secondary.grammar-concept{background:#6366f1}.image-vector-bars{display:flex;flex-direction:column;gap:.25rem}.image-vector-row{display:flex;align-items:center;gap:.35rem}.image-vector-label{width:32px;font-size:.55rem;font-weight:600;color:#fff;text-align:center;padding:.1rem .2rem;border-radius:2px;text-transform:uppercase}.image-vector-label.grammar-people{background:#3b82f6}.image-vector-label.grammar-animals{background:#10b981}.image-vector-label.grammar-environment{background:#059669}.image-vector-label.grammar-texture{background:#8b5cf6}.image-vector-label.grammar-object{background:#f59e0b}.image-vector-label.grammar-abstract{background:#ec4899}.image-vector-label.grammar-concept{background:#6366f1}.image-vector-bar-bg{flex:1;height:6px;background:#374151;border-radius:3px;overflow:hidden}.image-vector-bar-fill{height:100%;border-radius:3px}.image-vector-bar-fill.grammar-people{background:#3b82f6}.image-vector-bar-fill.grammar-animals{background:#10b981}.image-vector-bar-fill.grammar-environment{background:#059669}.image-vector-bar-fill.grammar-texture{background:#8b5cf6}.image-vector-bar-fill.grammar-object{background:#f59e0b}.image-vector-bar-fill.grammar-abstract{background:#ec4899}.image-vector-bar-fill.grammar-concept{background:#6366f1}.image-vector-score{width:28px;font-size:.65rem;font-family:monospace;color:#6b7280;text-align:right}.stage-image-card.intent-card{min-height:auto}.intent-assignment{display:flex;align-items:center;gap:.5rem}.intent-name{font-weight:600;color:#a78bfa;font-size:.9rem}.intent-confidence{padding:.15rem .4rem;border-radius:4px;font-size:.7rem;font-weight:600}.intent-confidence.high{background:#10b98133;color:#6ee7b7}.intent-confidence.medium{background:#f59e0b33;color:#fcd34d}.intent-confidence.low{background:#ef444433;color:#fca5a5}.intent-scores{display:flex;gap:.5rem;flex-wrap:wrap}.score-item{font-size:.7rem;font-family:monospace;padding:.1rem .3rem;background:#374151;border-radius:3px;color:#9ca3af}.score-item.penalty{background:#ef444433;color:#fca5a5}.intent-alternatives{display:flex;flex-wrap:wrap;gap:.4rem}.alt-intent{font-size:.75rem;color:#6b7280;padding:.15rem .4rem;background:#1d1d1d;border-radius:4px;border:1px solid #374151}.alt-score{font-family:monospace;font-size:.65rem;color:#4b5563}.title-score{padding:.15rem .4rem;border-radius:4px;font-size:.7rem;font-weight:600;margin-left:auto}.title-score.high{background:#10b98133;color:#6ee7b7}.title-score.medium{background:#f59e0b33;color:#fcd34d}.title-score.low{background:#ef444433;color:#fca5a5}.title-score-breakdown{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.3rem}.score-component{font-size:.7rem;font-family:monospace;padding:.1rem .4rem;background:#374151;border-radius:3px;color:#9ca3af}.score-component:first-child{background:#3b82f633;color:#93c5fd}.score-component:nth-child(2){background:#8b5cf633;color:#c4b5fd}.score-component:nth-child(3){background:#10b98133;color:#6ee7b7}.score-component:nth-child(4){background:#f59e0b33;color:#fcd34d}.title-score-inline{font-size:.7rem;font-weight:600;padding:.1rem .3rem;border-radius:3px;margin-left:.5rem}.title-score-inline.high{background:#10b98133;color:#6ee7b7}.title-score-inline.medium{background:#f59e0b33;color:#fcd34d}.title-score-inline.low{background:#ef444433;color:#fca5a5}.grammar-tag.grammar-people{background:#3b82f6}.grammar-tag.grammar-animals{background:#10b981}.grammar-tag.grammar-environment{background:#059669}.grammar-tag.grammar-texture{background:#8b5cf6}.grammar-tag.grammar-object{background:#f59e0b}.grammar-tag.grammar-abstract{background:#ec4899}.grammar-tag.grammar-concept{background:#6366f1}.shot-tag{background:#6b72804d;color:#9ca3af}.style-tag{background:#6b728033;color:#9ca3af}.lab-modal-wide{max-width:800px}.lab-grammar-distribution{background:#2a2a2a;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #374151}.lab-grammar-distribution strong{color:#d1d5db;display:block;margin-bottom:.5rem}.grammar-badges{display:flex;flex-wrap:wrap;gap:.5rem}.grammar-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.8rem;font-weight:500;color:#fff}.grammar-badge.grammar-people{background:#3b82f6}.grammar-badge.grammar-animals{background:#10b981}.grammar-badge.grammar-environment{background:#059669}.grammar-badge.grammar-texture{background:#8b5cf6}.grammar-badge.grammar-object{background:#f59e0b}.grammar-badge.grammar-abstract{background:#ec4899}.grammar-badge.grammar-concept{background:#6366f1}.keyword-buckets{display:inline-flex;gap:.5rem;margin-left:.75rem}.bucket{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;color:#fff;cursor:help}.bucket-literal{background:#10b981}.bucket-intent{background:#3b82f6}.bucket-concept{background:#8b5cf6}.lab-mode-toggles{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem;background:#2a2a2a;border-radius:8px;border:1px solid #374151}.lab-toggle-group{display:flex;flex-direction:column;gap:.5rem}.lab-toggle-group strong{color:#9ca3af;font-size:.85rem}.toggle-buttons{display:flex;gap:.5rem}.toggle-btn{padding:.5rem 1rem;border:1px solid #4b5563;background:transparent;color:#9ca3af;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.toggle-btn:hover{border-color:#8b5cf6;color:#d1d5db}.toggle-btn.active{background:#8b5cf6;border-color:#8b5cf6;color:#fff}.lab-intents-section{margin-bottom:1.5rem}.lab-intents-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;color:#d1d5db}.lab-intents-list{max-height:200px;overflow:auto;border:1px solid #374151;border-radius:8px;background:#2a2a2a;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:0}.lab-intent-item{display:flex;align-items:center;padding:.5rem .75rem;cursor:pointer;transition:background-color .15s;-webkit-user-select:none;user-select:none;color:#d1d5db;border-bottom:1px solid #374151;border-right:1px solid #374151;font-size:.9rem}.lab-intent-item:hover{background:#374151}.lab-intent-item.selected{background:#8b5cf626}.lab-intent-checkbox{margin-right:.5rem;width:14px;height:14px;cursor:pointer;pointer-events:none;accent-color:#8b5cf6}.lab-grammar-intents{margin-bottom:1.5rem;padding:1rem;background:#2a2a2a;border-radius:8px;border:1px solid #374151}.lab-grammar-intents>strong{color:#d1d5db;display:block;margin-bottom:.75rem}.grammar-intent-pools{display:flex;flex-wrap:wrap;gap:1rem}.grammar-intent-pool{flex:1;min-width:200px;background:#1d1d1d;border-radius:6px;overflow:hidden}.grammar-pool-header{padding:.5rem .75rem;font-weight:600;font-size:.85rem;color:#fff}.grammar-pool-header.grammar-people{background:#3b82f6}.grammar-pool-header.grammar-animals{background:#10b981}.grammar-pool-header.grammar-environment{background:#059669}.grammar-pool-header.grammar-texture{background:#8b5cf6}.grammar-pool-header.grammar-object{background:#f59e0b}.grammar-pool-header.grammar-abstract{background:#ec4899}.grammar-pool-header.grammar-concept{background:#6366f1}.grammar-pool-intents{padding:.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.grammar-intent-tag{background:#374151;color:#d1d5db;padding:.2rem .5rem;border-radius:4px;font-size:.8rem}.grammar-intent-more{color:#6b7280;font-size:.8rem;font-style:italic}.lab-custom-intents{margin-bottom:1.5rem;color:#d1d5db}.lab-custom-intents strong{display:block;margin-bottom:.75rem}.lab-angle{background:#8b5cf61a;padding:.5rem;border-radius:4px;margin-top:.5rem}.lab-angle strong{color:#a78bfa}.lab-angles-section{margin-bottom:1.5rem}.lab-angles-list{max-height:200px;overflow:auto;border:1px solid #374151;border-radius:8px;background:#2a2a2a}.lab-angle-item{display:flex;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background-color .15s;-webkit-user-select:none;user-select:none;color:#d1d5db}.lab-angle-item:hover{background:#374151}.lab-angle-item.selected{background:#8b5cf626}.lab-angle-checkbox{margin-right:.75rem;width:16px;height:16px;cursor:pointer;pointer-events:none;accent-color:#8b5cf6}.lab-modal-stage-review{max-width:1100px;max-height:90vh}.lab-stage-summary{background:linear-gradient(135deg,#2a2a2a,#1d1d1d);padding:1.25rem;border-radius:10px;margin-bottom:1.5rem;border:1px solid #374151}.lab-stage-summary h4{margin:0 0 .75rem;color:#8b5cf6;font-size:1rem;font-weight:600}.lab-stage-summary p{margin:0;color:#9ca3af;font-size:.9rem;line-height:1.5}.lab-stage-results{margin-bottom:1.5rem}.stage-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.stage-image-card{background:#2a2a2a;border:1px solid #374151;border-radius:10px;overflow:hidden;transition:border-color .2s,transform .2s}.stage-image-card:hover{border-color:#8b5cf6;transform:translateY(-2px)}.stage-card-header{padding:.75rem;background:#1d1d1d;border-bottom:1px solid #374151;display:flex;align-items:center;gap:.5rem}.stage-card-filename{font-size:.8rem;color:#d1d5db;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.stage-card-badge{padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase}.stage-card-badge.grammar-people{background:#3b82f6}.stage-card-badge.grammar-animals{background:#10b981}.stage-card-badge.grammar-environment{background:#059669}.stage-card-badge.grammar-texture{background:#8b5cf6}.stage-card-badge.grammar-object{background:#f59e0b}.stage-card-badge.grammar-abstract{background:#ec4899}.stage-card-badge.grammar-concept{background:#6366f1}.stage-card-body{padding:.75rem}.stage-field{margin-bottom:.75rem}.stage-field:last-child{margin-bottom:0}.stage-field-label{font-size:.7rem;text-transform:uppercase;color:#6b7280;margin-bottom:.25rem;font-weight:600;letter-spacing:.5px}.stage-field-value{font-size:.85rem;color:#d1d5db;line-height:1.4}.stage-field-value.description{font-size:.8rem;color:#9ca3af;max-height:60px;overflow-y:auto}.stage-field-value.title{font-weight:500;color:#e5e7eb}.stage-field-value.intent{color:#a78bfa;font-weight:500}.stage-field-value.category{color:#10b981}.stage-entity-tags{display:flex;flex-wrap:wrap;gap:.35rem}.stage-entity-tag{background:#374151;color:#9ca3af;padding:.15rem .4rem;border-radius:3px;font-size:.7rem}.stage-entity-tag.subject{background:#3b82f633;color:#93c5fd}.stage-entity-tag.object{background:#f59e0b33;color:#fcd34d}.stage-entity-tag.setting{background:#10b98133;color:#6ee7b7}.stage-keyword-buckets{display:flex;gap:.5rem;margin-bottom:.5rem}.stage-bucket{display:flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600}.stage-bucket.literal{background:#10b98133;color:#6ee7b7}.stage-bucket.intent{background:#3b82f633;color:#93c5fd}.stage-bucket.concept{background:#8b5cf633;color:#c4b5fd}.stage-keywords-preview{font-size:.75rem;color:#6b7280;line-height:1.4;max-height:40px;overflow:hidden}.stage-navigation{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#2a2a2a;border-radius:8px;margin-bottom:1rem}.stage-nav-info{color:#9ca3af;font-size:.9rem}.stage-nav-current{color:#8b5cf6;font-weight:600}.stage-indicators{display:flex;gap:.5rem;align-items:center}.stage-dot{width:10px;height:10px;border-radius:50%;background:#374151;transition:background .2s,transform .2s}.stage-dot.completed{background:#10b981}.stage-dot.current{background:#8b5cf6;transform:scale(1.3)}.stage-dot.pending{background:#374151}.lab-stage-continue-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.lab-stage-continue-btn:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 4px 15px #8b5cf666}.lab-stage-continue-btn.disabled{background:#4b5563;cursor:not-allowed}.lab-stage-continue-btn .arrow{font-size:1.2rem}.stage-cluster-concept{background:linear-gradient(135deg,#8b5cf61a,#6366f11a);border:1px solid rgba(139,92,246,.3);border-radius:10px;padding:1.5rem;text-align:center;margin-bottom:1rem}.stage-cluster-concept h4{color:#8b5cf6;margin:0 0 .75rem;font-size:1.1rem}.stage-cluster-concept p{color:#d1d5db;margin:0;font-size:1rem;line-height:1.6}.stage-themes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.stage-theme-card{background:#2a2a2a;border-radius:10px;padding:1rem;border:1px solid #374151;transition:border-color .2s,transform .2s}.stage-theme-card:hover{transform:translateY(-2px)}.stage-theme-card.visual{border-left:3px solid #3b82f6}.stage-theme-card.visual:hover{border-color:#3b82f6}.stage-theme-card.semantic{border-left:3px solid #8b5cf6}.stage-theme-card.semantic:hover{border-color:#8b5cf6}.stage-theme-card.market{border-left:3px solid #10b981}.stage-theme-card.market:hover{border-color:#10b981}.stage-theme-card.psychology{border-left:3px solid #f59e0b}.stage-theme-card.psychology:hover{border-color:#f59e0b}.theme-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.theme-icon{font-size:1.25rem}.theme-card-header h5{margin:0;color:#e5e7eb;font-size:.9rem;font-weight:600}.theme-subtitle{font-size:.7rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-left:auto}.stage-theme-card p{margin:0;color:#9ca3af;font-size:.85rem;line-height:1.5}@media (max-width: 768px){.stage-themes-grid{grid-template-columns:1fr}}.lab-themes-compact{background:#2a2a2a;border-radius:10px;padding:1rem;margin-bottom:1rem;border:1px solid #374151}.themes-compact-row{display:flex;gap:1rem;margin-bottom:.75rem}.themes-compact-row:last-child{margin-bottom:0}.theme-compact-item{flex:1;display:flex;align-items:flex-start;gap:.5rem;padding:.5rem;background:#1d1d1d;border-radius:6px;border-left:3px solid #374151}.theme-compact-item.visual{border-left-color:#3b82f6}.theme-compact-item.semantic{border-left-color:#8b5cf6}.theme-compact-item.market{border-left-color:#10b981}.theme-compact-item.psychology{border-left-color:#f59e0b}.theme-compact-icon{font-size:1rem;flex-shrink:0}.theme-compact-label{font-size:.7rem;font-weight:600;color:#6b7280;text-transform:uppercase;flex-shrink:0}.theme-compact-text{font-size:.8rem;color:#d1d5db;line-height:1.4}@media (max-width: 768px){.themes-compact-row{flex-direction:column}}.lab-stepbystep-toggle{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#2a2a2a;border-radius:8px;margin-bottom:1rem;border:1px solid #374151}.lab-stepbystep-toggle label{color:#d1d5db;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:.5rem}.lab-stepbystep-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#8b5cf6;cursor:pointer}.lab-stepbystep-help{font-size:.8rem;color:#6b7280}.stage-title-display{font-size:.85rem;color:#d1d5db;padding:.5rem;background:#1d1d1d;border-radius:4px;border-left:3px solid #8b5cf6}@media (max-width: 768px){.lab-container{margin:10px;padding:20px}.lab-dropzone{padding:2rem 1rem}.lab-title{font-size:2rem}.lab-modal{padding:1.5rem;width:95%}.lab-angles-header{flex-direction:column;align-items:flex-start;gap:.5rem}.lab-custom-input-row{flex-direction:column}}.title-plan-card{border-left:3px solid #8b5cf6}.title-plan-card .subject-value{font-size:1.1rem;font-weight:600;color:#a78bfa}.title-plan-card .descriptor-tags{display:flex;flex-wrap:wrap;gap:.4rem}.title-plan-card .desc-tag{font-size:.75rem;padding:.2rem .5rem;border-radius:4px;background:#374151}.title-plan-card .desc-tag.visual{background:#3b82f6;color:#fff}.title-plan-card .desc-tag.material{background:#f59e0b;color:#000}.title-plan-card .top-candidate{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#1f2937;border-radius:6px;border:1px solid #4b5563}.title-plan-card .candidate-title{color:#a78bfa;font-weight:500;flex:1}.title-plan-card .candidate-score{color:#10b981;font-size:.85rem;font-weight:600}.title-plan-card .other-candidates{display:flex;flex-direction:column;gap:.3rem}.title-plan-card .other-candidate{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:#9ca3af}.title-plan-card .candidate-pattern{color:#6b7280;font-family:monospace;font-size:.7rem}.title-plan-card .candidate-title-small{flex:1;color:#d1d5db}.title-plan-card .candidate-score-small{color:#6b7280}.title-plan-card .error-text{color:#ef4444}.stage-summary-stats{display:flex;gap:1.5rem;margin-top:1rem}.stage-summary-stats .stat-item{display:flex;flex-direction:column;align-items:center}.stage-summary-stats .stat-value{font-size:1.5rem;font-weight:700;color:#8b5cf6}.stage-summary-stats .stat-item.error .stat-value{color:#ef4444}.stage-summary-stats .stat-label{font-size:.85rem;color:#9ca3af}.container{max-width:1200px;width:100%;background:#1d1d1d;border:1px solid #000000;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;padding-bottom:20px;border-bottom:2px solid #e5e7eb}h1{text-align:center;color:#667eea;margin-bottom:10px;font-size:2.5rem}.subtitle{text-align:center;color:#9ca3af;margin-bottom:30px}.auth-container{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%}.auth-form{background:#1d1d1d;border:1px solid #000000;padding:40px;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px}.auth-title{text-align:center;margin-bottom:30px;color:#9ca3af;font-size:1.8rem}.form-group{margin-bottom:1rem}.form-label{color:#9ca3af;font-weight:500;margin-bottom:8px;display:block}.form-input{width:100%;padding:12px;background:#0e0e0e;color:#d1d5db;border:2px solid #4b5563;border-radius:8px;font-size:16px;transition:border-color .3s}.form-input:focus{outline:none;border-color:#4f46e5;background:#0e0e0e}.form-input::placeholder{color:#6b7280}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4338ca,#6d28d9);transform:translateY(-1px)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-secondary{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:14px;text-decoration:underline;transition:color .2s}.btn-secondary:hover{color:#d1d5db}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#1d1d1d;border-bottom:1px solid #374151}.header-title{font-size:1.5rem;font-weight:700;color:#667eea}.header-user{font-size:.875rem;color:#9ca3af;margin-left:1rem}.btn-logout{padding:.5rem 1rem;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;color:#fff;font-size:.875rem;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-logout:hover{transform:translateY(-1px)}.upload-container{background:#1d1d1d;border:1px solid #000000;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;margin:20px;max-width:1200px}.upload-title{text-align:center;color:#667eea;margin-bottom:10px;font-size:2.5rem}.credits-info{text-align:center;color:#9ca3af;margin-bottom:30px;font-size:.875rem}.dropzone{border:2px dashed #4b5563;border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#2d2d2d;margin:20px 0}.dropzone:hover{border-color:#667eea;background:#3d3d3d}.dropzone.active{border-color:#667eea;background:#3d3d3d;transform:scale(1.02)}.dropzone.uploading{pointer-events:none;opacity:.7}.dropzone-text{font-size:1.25rem;color:#9ca3af;margin-bottom:.5rem}.dropzone-subtext{font-size:.875rem;color:#6b7280}.progress-container{text-align:center;padding:20px}.progress-title{font-size:1.125rem;font-weight:500;color:#9ca3af;margin-bottom:.5rem}.progress-stages{display:flex;justify-content:center;align-items:center;gap:2rem;margin:1.5rem 0}.stage{display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.4;transition:all .3s ease}.stage.active,.stage.completed{opacity:1}.stage-dot{width:12px;height:12px;border-radius:50%;background:#374151;border:2px solid #4b5563;transition:all .3s ease}.stage.active .stage-dot{background:#667eea;border-color:#667eea;box-shadow:0 0 12px #667eea80;animation:pulse 2s infinite}.stage.completed .stage-dot{background:#10b981;border-color:#10b981}.stage-label{font-size:.75rem;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stage.active .stage-label{color:#667eea}.stage.completed .stage-label{color:#10b981}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.progress-details{font-size:.875rem;color:#6b7280;margin-bottom:1rem;font-style:italic}.progress-bar{width:100%;height:12px;background-color:#374151;border-radius:6px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .3s ease-in-out}.progress-text{font-size:.875rem;color:#9ca3af;margin-top:.5rem}.stage-progress-list{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.stage-progress-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#2a2a2a;border-radius:8px;border:1px solid #374151;transition:all .3s ease}.stage-progress-item.completed{border-color:#10b981;background:#1f2937}.stage-progress-label{font-size:.875rem;font-weight:500;color:#9ca3af;text-transform:capitalize}.stage-progress-item.completed .stage-progress-label{color:#10b981}.stage-progress-item .progress-bar{margin:0}.stage-progress-item.completed .progress-fill{background:linear-gradient(135deg,#10b981,#059669)}.stage-progress-item .progress-text{margin:0;text-align:right;font-size:.75rem}.results-container{margin-top:3rem;background:#1d1d1d;border-radius:12px;padding:30px}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:15px;border-bottom:1px solid #374151}.results-title{font-size:1.5rem;font-weight:600;color:#667eea}.download-buttons{display:flex;gap:12px;align-items:center}.btn-download{padding:12px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-download:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-download-optimized{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.btn-download-optimized:hover{box-shadow:0 4px 12px #8b5cf64d}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.image-card{background:#2d2d2d;border:1px solid #404040;border-radius:12px;padding:1.5rem;transition:all .3s ease}.image-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.image-preview{width:100%;height:10rem;object-fit:cover;border-radius:8px;margin-bottom:1rem}.image-info{font-size:.875rem;line-height:1.4}.image-filename{font-weight:600;color:#d1d5db;margin-bottom:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.image-dimensions{color:#9ca3af;margin-bottom:.25rem}.image-size{color:#6b7280;margin-bottom:.75rem}.image-metadata{font-size:.75rem;color:#9ca3af;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #404040}.image-metadata strong{color:#d1d5db}.image-metadata p{margin-bottom:.5rem}@media (max-width: 768px){.upload-container{margin:10px;padding:20px}.dropzone{padding:2rem 1rem}.image-grid{grid-template-columns:1fr}.header{padding:1rem}.results-header{flex-direction:column;gap:1rem;align-items:stretch}.upload-title{font-size:2rem}}
