@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=IBM+Plex+Sans:wght@400;500;600&display=swap";:root{--bg-primary: #0a0f0d;--bg-secondary: #111916;--bg-tertiary: #1a2420;--bg-card: #151d19;--bg-card-hover: #1d2a24;--accent-primary: #00c853;--accent-secondary: #69f0ae;--accent-tertiary: #b9f6ca;--accent-dark: #00a843;--text-primary: #e8f5e9;--text-secondary: #a5d6a7;--text-muted: #66bb6a;--text-dim: #4a635a;--border-color: #2e4238;--border-light: #3d5a4c;--danger: #ff5252;--warning: #ffab40;--success: #69f0ae;--shadow-sm: 0 2px 8px rgba(0, 200, 83, .05);--shadow-md: 0 4px 20px rgba(0, 200, 83, .08);--shadow-lg: 0 8px 40px rgba(0, 200, 83, .12);--shadow-glow: 0 0 30px rgba(0, 200, 83, .2);--font-heading: "Manrope", sans-serif;--font-body: "IBM Plex Sans", sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden}body{overflow-x:hidden;font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:0;width:100%}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(0,200,83,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(105,240,174,.05) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(0,168,67,.03) 0%,transparent 70%);pointer-events:none;z-index:-1}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;color:var(--text-primary)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-secondary)}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}input,textarea,select{font-family:var(--font-body);font-size:1rem}img{max-width:100%;height:auto}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}::selection{background:var(--accent-primary);color:var(--bg-primary)}.container{max-width:1400px;margin:0 auto;padding:0 24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-normal)}.btn-primary{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-dark) 100%);color:var(--bg-primary);box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-light)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.search-bar{position:relative;width:100%;max-width:600px;margin:0 auto}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:16px;color:var(--text-dim);pointer-events:none}.search-input{width:100%;padding:14px 48px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:1rem;transition:all var(--transition-normal)}.search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00c8531a}.search-input::placeholder{color:var(--text-dim)}.search-clear{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;color:var(--text-dim);transition:all var(--transition-fast)}.search-clear:hover{background:var(--bg-card);color:var(--text-primary)}.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);z-index:50}.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background var(--transition-fast)}.search-result-item:hover{background:var(--bg-card-hover)}.result-image{position:relative;width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-tertiary);flex-shrink:0}.result-image img{width:100%;height:100%;object-fit:cover}.result-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-dim)}.result-info{display:flex;flex-direction:column;gap:4px;overflow:hidden}.result-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-category{font-size:.85rem;color:var(--text-muted)}.search-loading{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%)}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-mobile{background:#08080afa;border-bottom:none}.header-mobile .logo-text,.header-mobile .nav-link.active,.header-mobile .search-toggle:hover,.header-mobile .nav-link:hover{color:#ffb5a7}.header-content{display:flex;align-items:center;justify-content:space-between;height:72px}.logo{text-decoration:none}.logo-icon{display:flex;flex-direction:column;align-items:flex-start}.logo-text{font-family:var(--font-heading);font-size:1.5rem;font-weight:800;color:var(--accent-primary);line-height:1;letter-spacing:-.5px}.logo-sub{font-size:.75rem;font-weight:500;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}.nav{display:flex;gap:8px}.nav-link{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all var(--transition-normal)}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{background:var(--bg-tertiary);color:var(--accent-primary)}.header-actions{display:flex;align-items:center;gap:12px}.search-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-secondary);transition:all var(--transition-normal)}.search-toggle:hover{background:var(--bg-card-hover);color:var(--accent-primary)}.logout-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);transition:all var(--transition-normal);border:1px solid transparent}.logout-button:hover{background:#f443361a;color:#f44336;border-color:#f443364d}.search-dropdown{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:16px 0}.header-locked{pointer-events:none;opacity:.5}.header-locked .nav-link,.header-locked .logo,.header-locked .search-toggle,.header-locked .logout-button{pointer-events:none;cursor:not-allowed}.nav-disabled .nav-link{opacity:.4;cursor:not-allowed}@media(max-width:768px){.header-content{min-width:0;overflow:hidden}.nav{flex-shrink:1;min-width:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:0 4px}.nav::-webkit-scrollbar{display:none}.nav-link{flex-shrink:0;padding:10px 12px}.nav-link span{display:none}.logo{flex-shrink:0}.logo-sub{display:none}.header-actions{flex-shrink:0}}.category-card{display:block;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal);text-decoration:none}.category-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.category-preview{position:relative;aspect-ratio:4/3;background:var(--bg-tertiary);overflow:hidden}.preview-grid{display:grid;width:100%;height:100%}.preview-1{grid-template-columns:1fr}.preview-2{grid-template-columns:1fr 1fr}.preview-3{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.preview-3 .preview-item:first-child{grid-row:span 2}.preview-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.preview-item{overflow:hidden}.preview-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.category-card:hover .preview-item img{transform:scale(1.05)}.preview-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim)}.category-overlay{position:absolute;bottom:8px;right:8px;display:flex;align-items:center;gap:6px;padding:6px 12px;background:#0a0f0dd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.85rem;font-weight:500}.category-info{padding:16px}.category-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.category-count{font-size:.9rem;color:var(--text-muted)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.photo-grid-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 20px;color:var(--text-muted)}.photo-grid-empty{text-align:center;padding:80px 20px;color:var(--text-muted)}.photo-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-normal)}.photo-item:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:var(--shadow-md)}.photo-image{position:relative;aspect-ratio:1;background:var(--bg-tertiary);overflow:hidden}.photo-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.photo-item:hover .photo-image img{transform:scale(1.08)}.photo-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0a0f0dcc;opacity:0;transition:opacity var(--transition-normal)}.photo-item:hover .photo-overlay{opacity:1}.photo-generate-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-dark) 100%);color:var(--bg-primary);border-radius:var(--radius-md);font-weight:600;font-size:.9rem;transform:translateY(10px);transition:all var(--transition-normal)}.photo-item:hover .photo-generate-btn{transform:translateY(0)}.photo-generate-btn:hover{box-shadow:var(--shadow-glow)}.photo-info{padding:12px}.photo-name{display:block;font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.photo-generate-btn span{display:none}}.home-page{padding-bottom:60px}.hero-section{text-align:center;padding:40px 20px 50px}.hero-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-dark) 100%);border-radius:var(--radius-xl);color:var(--bg-primary);margin-bottom:24px;box-shadow:var(--shadow-glow)}.hero-title{font-size:2.5rem;font-weight:800;margin-bottom:12px;background:linear-gradient(135deg,var(--accent-secondary) 0%,var(--accent-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.1rem;color:var(--text-secondary);max-width:500px;margin:0 auto 32px}.view-toggle{display:inline-flex;gap:4px;padding:4px;background:var(--bg-tertiary);border-radius:var(--radius-lg)}.toggle-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all var(--transition-normal)}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{background:var(--bg-card);color:var(--accent-primary);box-shadow:var(--shadow-sm)}.section-title{font-size:1.5rem;margin-bottom:24px;color:var(--text-primary)}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}@media(max-width:768px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.toggle-btn span{display:none}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}}.category-page{padding-bottom:60px}.category-header{padding:20px 0 40px}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-weight:500;margin-bottom:24px;transition:color var(--transition-fast)}.back-link:hover{color:var(--accent-primary)}.category-title-section{display:flex;align-items:center;gap:20px}.category-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--accent-primary)}.category-page-title{font-size:2rem;margin-bottom:4px}.category-count{color:var(--text-muted)}@media(max-width:768px){.category-page-title{font-size:1.5rem}.category-icon{width:48px;height:48px}}.history-page{padding-bottom:60px}.history-header{padding:20px 0 40px}.history-title-section{display:flex;align-items:center;gap:20px}.history-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--accent-primary)}.history-page-title{font-size:2rem;margin-bottom:4px}.history-count{color:var(--text-muted)}.loading-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 20px;color:var(--text-muted)}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 20px;text-align:center;color:var(--text-dim)}.history-empty h3{color:var(--text-secondary)}.history-grid{display:flex;flex-direction:column;gap:20px}.history-item{display:grid;grid-template-columns:auto 1fr auto;gap:20px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast)}.history-item:hover{border-color:var(--border-light)}.history-images{display:flex;align-items:center;gap:12px}.history-source,.history-result{position:relative;width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary)}.history-source img,.history-result img{width:100%;height:100%;object-fit:cover}.image-label{position:absolute;bottom:4px;left:4px;right:4px;padding:2px 6px;background:#0a0f0dd9;border-radius:4px;font-size:.7rem;color:var(--text-secondary);text-align:center}.no-result{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim)}.history-arrow{color:var(--text-dim);font-size:1.2rem}.history-info{display:flex;flex-direction:column;justify-content:center;gap:8px;overflow:hidden}.history-prompt{color:var(--text-primary);font-size:.95rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.history-meta{display:flex;align-items:center;gap:16px;font-size:.85rem;color:var(--text-muted)}.history-ratio{padding:2px 8px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.history-date{display:flex;align-items:center;gap:4px}.history-actions{display:flex;align-items:center;gap:8px}.action-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.action-btn:hover{background:var(--bg-card-hover);color:var(--accent-primary)}@media(max-width:768px){.history-item{grid-template-columns:1fr;gap:16px}.history-images,.history-actions{justify-content:center}.history-page-title{font-size:1.5rem}}.upload-page{padding:2rem 0;min-height:calc(100vh - 72px)}.upload-header{margin-bottom:2rem}.upload-header h1{display:flex;align-items:center;gap:.75rem;font-size:2rem;color:var(--text-primary);margin-bottom:.5rem}.upload-subtitle{color:var(--text-secondary);font-size:1rem}.upload-stats{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.stat-item{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.stat-item strong{color:var(--accent-primary)}.message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--radius-md);margin-bottom:1rem}.message.error{background:#f4433626;border:1px solid rgba(244,67,54,.3);color:#ff6b6b}.message.success{background:#4caf5026;border:1px solid rgba(76,175,80,.3);color:#81c784}.message button{margin-left:auto;background:none;color:inherit;opacity:.7}.message button:hover{opacity:1}.upload-zone-wrapper{margin-bottom:2rem}.upload-zone{display:flex;align-items:center;justify-content:center;padding:3rem;border:2px dashed var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-normal)}.upload-zone:hover:not(.disabled){border-color:var(--accent-primary);background:#4caf500d}.upload-zone.disabled{opacity:.5;cursor:not-allowed}.upload-zone.has-files{border-color:var(--accent-primary);border-style:solid}.upload-zone input{display:none}.upload-zone-content{text-align:center;color:var(--text-secondary)}.upload-zone-content svg{margin-bottom:1rem;color:var(--accent-primary);opacity:.7}.upload-zone-content p{font-size:1.1rem;margin-bottom:.5rem}.upload-zone-content span{font-size:.875rem;opacity:.7}.selected-files{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.selected-files h3{font-size:1rem;color:var(--text-primary);margin-bottom:1rem}.files-list{display:flex;flex-direction:column;gap:1rem}.file-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.file-preview{width:60px;height:60px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.file-preview img{width:100%;height:100%;object-fit:cover}.file-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.file-info input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.5rem .75rem;color:var(--text-primary);font-size:.9rem}.file-info input:focus{outline:none;border-color:var(--accent-primary)}.file-size{font-size:.75rem;color:var(--text-muted)}.remove-file{background:#f443361a;color:#f44336;width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.remove-file:hover{background:#f4433633}.upload-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;margin-top:1rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-weight:600;font-size:1rem;border-radius:var(--radius-md);box-shadow:0 4px 15px #4caf504d}.upload-button:hover:not(:disabled){box-shadow:0 6px 20px #4caf5066}.upload-button:disabled{opacity:.6;cursor:not-allowed}.upload-button .spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.pending-section{margin-top:3rem}.pending-section h2{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;color:var(--text-primary);margin-bottom:1.5rem}.pending-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.pending-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.pending-image{position:relative;aspect-ratio:4/3;background:var(--bg-tertiary)}.pending-image img{width:100%;height:100%;object-fit:cover}.pending-badge{position:absolute;top:.75rem;left:.75rem;background:#ffc107e6;color:#000;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600}.pending-info{padding:1rem}.pending-info h4{font-size:.95rem;color:var(--text-primary);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pending-date{font-size:.8rem;color:var(--text-muted)}.pending-actions{display:flex;gap:.5rem;padding:0 1rem 1rem}.category-select{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.5rem;color:var(--text-primary);font-size:.85rem;cursor:pointer}.category-select:focus{outline:none;border-color:var(--accent-primary)}.reject-btn{background:#f443361a;color:#f44336;width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.reject-btn:hover{background:#f4433633}@media(max-width:768px){.upload-stats{flex-direction:column;gap:.75rem}.pending-grid{grid-template-columns:1fr}.file-item{flex-wrap:wrap}.file-info{width:calc(100% - 76px)}.remove-file{margin-left:auto}}.aspect-ratio-selector{margin-bottom:20px}.aspect-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:12px}.aspect-options{display:flex;gap:12px;flex-wrap:wrap}.aspect-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);min-width:80px}.aspect-option:hover{border-color:var(--border-light);background:var(--bg-card-hover)}.aspect-option.active{border-color:var(--accent-primary);background:#00c8531a}.aspect-preview{width:32px;max-height:40px;background:var(--accent-primary);border-radius:4px;opacity:.6;transition:opacity var(--transition-fast)}.aspect-option.active .aspect-preview,.aspect-option:hover .aspect-preview{opacity:1}.aspect-name{font-weight:600;font-size:.9rem;color:var(--text-primary)}.aspect-desc{font-size:.75rem;color:var(--text-muted)}@media(max-width:480px){.aspect-options{display:grid;grid-template-columns:repeat(3,1fr)}.aspect-option{min-width:unset;padding:10px 8px}}.generation-lock-overlay{position:fixed;inset:0;background:#0a0f0df2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:9999}.generation-lock-content{text-align:center;max-width:400px;padding:2rem}.lock-animation{position:relative;display:flex;justify-content:center;align-items:center;height:100px;margin-bottom:2rem}.lock-circles{position:absolute;display:flex;gap:8px}.lock-circle{width:14px;height:14px;background:var(--accent-primary, #00c853);border-radius:50%;box-shadow:0 0 20px var(--accent-primary, #00c853)}.lock-icon{color:var(--accent-primary, #00c853);filter:drop-shadow(0 0 15px var(--accent-primary, #00c853));animation:lock-pulse 2s ease-in-out infinite}@keyframes lock-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 15px var(--accent-primary, #00c853))}50%{transform:scale(1.1);filter:drop-shadow(0 0 30px var(--accent-primary, #00c853))}}.lock-title{font-size:1.5rem;font-weight:700;color:var(--text-primary, #fff);margin-bottom:.5rem}.lock-subtitle{color:var(--text-secondary, #aaa);margin-bottom:2rem}.lock-progress-bar{width:100%;height:6px;background:var(--bg-tertiary, #333);border-radius:3px;overflow:hidden;margin-bottom:1.5rem}.lock-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary, #00c853),var(--accent-secondary, #69f0ae));border-radius:3px;transition:width .3s ease-out;box-shadow:0 0 10px var(--accent-primary, #00c853)}.lock-stage{font-size:1rem;color:var(--text-primary, #fff);margin-bottom:.5rem;font-weight:500}.lock-percent{font-size:2.5rem;font-weight:700;color:var(--accent-primary, #00c853);font-family:var(--font-heading, inherit)}.multi-page{padding:2rem 0;min-height:calc(100vh - 80px)}.multi-header{margin-bottom:2rem}.multi-title-section{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.multi-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff}.multi-page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.multi-subtitle{color:var(--text-secondary);margin:.25rem 0 0}.selection-panel{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:16px;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.selected-photos-preview{display:flex;gap:.75rem}.selected-thumb{position:relative;width:60px;height:60px;border-radius:8px;overflow:hidden;border:2px solid rgba(255,255,255,.5)}.selected-thumb img{width:100%;height:100%;object-fit:cover}.thumb-number{position:absolute;top:4px;left:4px;width:18px;height:18px;background:var(--primary-dark);color:#fff;border-radius:50%;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center}.remove-thumb{position:absolute;top:4px;right:4px;width:18px;height:18px;background:#0009;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.selected-thumb:hover .remove-thumb{opacity:1}.selection-actions{display:flex;align-items:center;gap:1rem}.selection-count{color:#ffffffe6;font-weight:600;font-size:1.1rem}.btn-clear{background:#fff3;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .2s}.btn-clear:hover{background:#ffffff4d}.multi-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-input-wrapper{flex:1;min-width:200px;display:flex;align-items:center;gap:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;padding:0 1rem}.search-input-wrapper svg{color:var(--text-tertiary)}.search-input{flex:1;border:none;background:transparent;padding:.75rem 0;font-size:1rem;color:var(--text-primary)}.search-input:focus{outline:none}.category-select{min-width:180px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;cursor:pointer}.multi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.multi-photo-card{background:var(--bg-secondary);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;border:2px solid transparent}.multi-photo-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001a}.multi-photo-card.selected{border-color:var(--primary-color);box-shadow:0 0 0 3px #4caf5033}.multi-photo-card.disabled{opacity:.5;cursor:not-allowed}.multi-photo-image{position:relative;aspect-ratio:1;overflow:hidden}.multi-photo-image img{width:100%;height:100%;object-fit:cover}.selection-badge{position:absolute;top:8px;right:8px;width:28px;height:28px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;box-shadow:0 2px 8px #0003}.disabled-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px}.multi-photo-name{padding:.75rem;font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.multi-modal{max-width:700px}.multi-source-photos{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem;flex-wrap:wrap}.multi-source-item{position:relative;width:120px;height:120px;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.multi-source-item img{width:100%;height:100%;object-fit:cover}.source-number{position:absolute;top:8px;left:8px;width:24px;height:24px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.result-refs{color:var(--text-secondary);font-size:.9rem}.loading-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.multi-page-title{font-size:1.5rem}.selection-panel{flex-direction:column;align-items:stretch}.selected-photos-preview,.selection-actions{justify-content:center}.multi-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.multi-source-item{width:80px;height:80px}}.freegen-page{padding:2rem 0;min-height:calc(100vh - 80px)}.freegen-header{margin-bottom:2rem}.freegen-title-section{display:flex;align-items:center;gap:1rem}.freegen-icon{width:64px;height:64px;background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff}.freegen-page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.freegen-subtitle{color:var(--text-secondary);margin:.25rem 0 0}.freegen-workspace{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem;max-width:700px;margin:0 auto}.section-label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary);margin-bottom:12px;font-size:1rem}.upload-section{margin-bottom:1.5rem}.upload-cards{display:flex;gap:1rem;flex-wrap:wrap}.upload-card{position:relative;width:180px;height:200px;border-radius:12px;overflow:hidden;flex-shrink:0}.upload-card.filled{box-shadow:0 4px 16px #00000026;border:2px solid var(--border-color)}.upload-card.filled img{width:100%;height:100%;object-fit:cover}.card-number{position:absolute;top:8px;left:8px;width:26px;height:26px;background:#7c3aed;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;box-shadow:0 2px 8px #0000004d}.card-remove{position:absolute;top:8px;right:8px;width:26px;height:26px;background:#0009;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.card-remove:hover{background:#dc3232cc}.card-filename{position:absolute;bottom:0;left:0;right:0;padding:6px 10px;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-card.empty{border:2px dashed var(--border-color);background:var(--bg-tertiary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);cursor:pointer;transition:all .2s}.upload-card.empty:hover{border-color:#7c3aed;color:#7c3aed;background:#7c3aed0d}.upload-card.empty span{font-size:.9rem;font-weight:500}.upload-hint{font-size:.75rem!important;color:var(--text-dim)!important;font-weight:400!important}.freegen-workspace .prompt-section{margin-bottom:1.5rem}.freegen-workspace .prompt-hint{font-size:.8rem;color:#7c3aed;margin-bottom:10px;padding:8px 12px;background:#7c3aed14;border-radius:var(--radius-sm);border-left:3px solid #7c3aed}.freegen-workspace .prompt-input{width:100%;padding:14px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;line-height:1.5;resize:vertical;transition:border-color var(--transition-fast)}.freegen-workspace .prompt-input:focus{border-color:#7c3aed;outline:none}.freegen-workspace .prompt-input::placeholder{color:var(--text-dim)}.freegen-workspace .prompt-input:disabled{opacity:.6;cursor:not-allowed}.freegen-actions{display:flex;justify-content:center;margin-top:1.5rem}.btn-large{padding:14px 40px!important;font-size:1.1rem!important;gap:10px}.freegen-result{max-width:700px;margin:0 auto}.freegen-result .result-section{text-align:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem}.freegen-result .result-image{max-width:100%;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-tertiary);margin-bottom:20px}.freegen-result .result-image img{width:100%;height:auto;display:block}.freegen-result .result-info{margin-bottom:20px}.freegen-result .result-info h3{color:#7c3aed;margin-bottom:8px}.freegen-result .result-prompt{color:var(--text-secondary);font-size:.9rem}.freegen-result .result-refs,.freegen-result .result-size{color:var(--text-muted);font-size:.85rem;margin-top:4px}.freegen-result-actions{display:flex;gap:12px;justify-content:center}.freegen-result-actions .btn{min-width:140px}.freegen-workspace .generation-progress{text-align:center;padding:40px 20px;background:linear-gradient(135deg,#7c3aed0d,#a855f70d);border-radius:var(--radius-lg);border:1px solid rgba(124,58,237,.2);margin-top:1.5rem}.freegen-workspace .progress-circle{background:#7c3aed;box-shadow:0 0 20px #7c3aed}.freegen-workspace .progress-icon{color:#7c3aed;filter:drop-shadow(0 0 10px #7c3aed)}.freegen-workspace .progress-bar-fill{background:linear-gradient(90deg,#7c3aed,#a855f7);box-shadow:0 0 10px #7c3aed}.freegen-workspace .progress-percent{color:#7c3aed}.freegen-workspace .error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ff52521a;border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);margin-bottom:0}@media(max-width:768px){.freegen-page-title{font-size:1.5rem}.freegen-workspace{padding:1.5rem}.upload-cards{justify-content:center}.upload-card{width:150px;height:170px}.freegen-result-actions{flex-direction:column}.freegen-result-actions .btn{width:100%}}.mobile-capture-page{min-height:calc(100vh - 80px);padding:2rem 0 4rem;background:radial-gradient(ellipse 60% 40% at 20% 30%,rgba(255,154,139,.06) 0%,transparent 50%),radial-gradient(ellipse 50% 50% at 85% 70%,rgba(167,139,250,.04) 0%,transparent 50%),radial-gradient(ellipse 40% 60% at 50% 90%,rgba(254,202,122,.04) 0%,transparent 45%),#08080a}.mobile-capture-container{position:relative;z-index:1}.mobile-capture-header{text-align:center;margin-bottom:3rem}.mobile-capture-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#ff9a8b26;border:1px solid rgba(255,154,139,.35);border-radius:999px;color:#ffb5a7;font-size:.85rem;font-weight:600;margin-bottom:1rem}.mobile-capture-title{display:flex;align-items:center;justify-content:center;gap:12px;font-size:2.5rem;font-weight:800;color:#f8fafc;margin:0 0 .75rem;letter-spacing:-.5px}.mobile-capture-title-icon{color:#feca7a;filter:drop-shadow(0 0 12px rgba(254,202,122,.4))}.mobile-capture-subtitle{font-size:1.1rem;color:#94a3b8;max-width:520px;margin:0 auto;line-height:1.6}.mobile-capture-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(300px,100%),1fr));grid-auto-rows:1fr;gap:1.5rem;max-width:1100px;margin:0 auto;width:100%}.mobile-capture-card{text-decoration:none;display:block}.mobile-capture-card-inner{background:#0f172acc;border:1px solid rgba(148,163,184,.12);border-radius:20px;padding:2rem;min-height:220px;height:100%;display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .3s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 24px #0000004d}.mobile-capture-card:hover .mobile-capture-card-inner{border-color:#94a3b840;box-shadow:0 8px 40px #0006}.mobile-capture-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:1.25rem;box-shadow:0 4px 20px #0000004d;flex-shrink:0}.mobile-capture-card-title{font-size:1.35rem;font-weight:700;color:#f8fafc;margin:0 0 .5rem}.mobile-capture-card-desc{font-size:.95rem;color:#94a3b8;line-height:1.5;margin:0 0 1.25rem;flex-grow:1;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.mobile-capture-card-cta{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.9rem;font-weight:600;color:#ffb5a7;transition:gap .2s}.mobile-capture-card:hover .mobile-capture-card-cta{gap:10px}.mobile-workspace-page{position:relative;min-height:calc(100vh - 80px);padding:2rem 0 4rem;background:#08080a}.mobile-workspace-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(255,154,139,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(254,202,122,.06) 0%,transparent 50%);pointer-events:none;z-index:0}.mobile-workspace-grid{position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 30% 40%,rgba(255,154,139,.05) 0%,transparent 50%),radial-gradient(ellipse 50% 70% at 70% 60%,rgba(167,139,250,.04) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 50% 80%,rgba(103,232,249,.03) 0%,transparent 45%),radial-gradient(ellipse 55% 55% at 80% 20%,rgba(254,202,122,.04) 0%,transparent 45%);pointer-events:none;z-index:0}.mobile-workspace-container{position:relative;z-index:1;max-width:640px;margin:0 auto}.mobile-workspace-header{margin-bottom:2rem}.mobile-workspace-back{display:inline-flex;align-items:center;gap:8px;color:#94a3b8;font-size:.9rem;text-decoration:none;margin-bottom:1rem;transition:color .2s}.mobile-workspace-back:hover{color:#ffb5a7}.mobile-workspace-title{font-size:1.75rem;font-weight:700;color:#f8fafc;margin:0 0 .5rem}.mobile-workspace-subtitle{font-size:1rem;color:#94a3b8;margin:0}.mobile-workspace-description{margin-top:1rem;padding:1rem 1.25rem;background:#94a3b80f;border:1px solid rgba(148,163,184,.12);border-radius:12px}.mobile-workspace-description p{margin:0;font-size:.9rem;color:#94a3b8;line-height:1.6}.mobile-workspace-description p strong{color:#e2e8f0}.mobile-workspace-card{background:#0f172ae6;border:1px solid rgba(148,163,184,.12);border-radius:20px;padding:2rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 24px #0000004d}.mobile-workspace-upload{border:2px dashed rgba(148,163,184,.25);border-radius:16px;padding:2.5rem;text-align:center;cursor:pointer;transition:all .3s;background:#0f172a80;margin-bottom:1.5rem}.mobile-workspace-upload:hover{border-color:#ff9a8b;background:#ff9a8b0d}.mobile-workspace-upload.has-image{padding:1rem;border-style:solid;border-color:#ff9a8b4d}.mobile-workspace-upload img{max-height:200px;border-radius:12px;display:block;margin:0 auto}.quicklayout-previews{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.quicklayout-preview-item{position:relative;width:80px;height:80px}.quicklayout-preview-item img{width:100%;height:100%;object-fit:cover;border-radius:10px;margin:0}.quicklayout-remove{position:absolute;top:-6px;right:-6px;width:24px;height:24px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.quicklayout-add{width:80px;height:80px;border:2px dashed rgba(148,163,184,.3);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#64748b;cursor:pointer;transition:border-color .2s}.quicklayout-add:hover{border-color:#ff9a8b;color:#ff9a8b}.branding-upload-section{margin-bottom:1.5rem}.branding-upload-section .mobile-workspace-upload{margin-bottom:0}.branding-mood-desc{margin-top:8px;min-height:48px;resize:none}.mobile-aspect-selector{margin-bottom:1.5rem}.mobile-aspect-label{display:block;font-size:.9rem;color:#94a3b8;margin-bottom:10px}.mobile-aspect-options{display:flex;flex-wrap:wrap;gap:8px}.mobile-aspect-option{padding:8px 14px;background:#0f172acc;border:1px solid rgba(148,163,184,.2);border-radius:10px;color:#94a3b8;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.mobile-aspect-option:hover{border-color:#ff9a8b66;color:#e2e8f0}.mobile-aspect-option.active{border-color:#ff9a8b;background:#ff9a8b26;color:#ffb5a7}.social-type-selector{display:flex;flex-direction:column;gap:10px;margin-bottom:1.5rem}.social-type-option{display:flex;flex-direction:column;align-items:flex-start;padding:14px 18px;background:#0f172acc;border:1px solid rgba(148,163,184,.2);border-radius:12px;color:#94a3b8;font-size:.95rem;cursor:pointer;transition:all .2s;text-align:left}.social-type-option:hover{border-color:#8b5cf666;color:#e2e8f0}.social-type-option.active{border-color:#8b5cf6;background:#8b5cf61f;color:#c4b5fd}.social-type-label{font-weight:600;margin-bottom:4px}.social-type-desc{font-size:.8rem;color:inherit;opacity:.85}.mobile-workspace-prompt{width:100%;padding:14px 16px;background:#0f172acc;border:1px solid rgba(148,163,184,.15);border-radius:12px;color:#f8fafc;font-size:1rem;margin-bottom:1.5rem;resize:vertical;min-height:80px}.mobile-workspace-prompt::placeholder{color:#64748b}.mobile-workspace-prompt:focus{outline:none;border-color:#ff9a8b}.mobile-workspace-btn{width:100%;padding:16px 24px;background:linear-gradient(135deg,#ff9a8b,#feca7a);color:#1a1a1d;font-size:1.1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s;box-shadow:0 4px 20px #ff9a8b4d}.mobile-workspace-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #ff9a8b66}.mobile-workspace-btn:disabled{opacity:.6;cursor:not-allowed}.mobile-workspace-progress{text-align:center;padding:2rem;background:#ff9a8b14;border-radius:16px;border:1px solid rgba(255,154,139,.2);margin:1.5rem 0}.mobile-workspace-progress-bar{height:6px;background:#94a3b833;border-radius:3px;overflow:hidden;margin:1rem 0}.mobile-workspace-progress-fill{height:100%;background:linear-gradient(90deg,#ff9a8b,#feca7a);border-radius:3px;transition:width .3s}.mobile-workspace-result{margin-top:2rem;text-align:center}.mobile-workspace-result img{max-width:100%;border-radius:16px;box-shadow:0 8px 32px #0006;margin-bottom:1rem}.mobile-workspace-result-actions{display:flex;gap:12px;justify-content:center;margin-top:1rem}.mobile-workspace-error{padding:14px 18px;background:#ef444426;border:1px solid rgba(239,68,68,.4);border-radius:12px;color:#f87171;margin-bottom:1rem;display:flex;align-items:center;gap:10px}@media(max-width:768px){.mobile-capture-page{padding:1rem 0 2rem;min-height:calc(100vh - 72px);width:100%;max-width:100vw}.mobile-capture-container{padding:0 16px;width:100%;max-width:100%}.mobile-capture-header{margin-bottom:2rem}.mobile-capture-badge{padding:6px 12px;font-size:.8rem;margin-bottom:.75rem}.mobile-capture-title{font-size:1.5rem;gap:8px;flex-wrap:wrap;justify-content:center}.mobile-capture-title-icon{width:24px;height:24px}.mobile-capture-subtitle{font-size:.95rem;padding:0 8px;line-height:1.5}.mobile-capture-cards{grid-template-columns:1fr;gap:1rem;padding:0 4px}.mobile-capture-card-inner{padding:1.25rem;border-radius:16px;align-items:center;text-align:center}.mobile-capture-card-icon{width:48px;height:48px;margin-bottom:1rem}.mobile-capture-card-title{font-size:1.2rem;text-align:center}.mobile-capture-card-desc{font-size:.9rem;margin-bottom:1rem;text-align:center}.mobile-capture-card-cta{font-size:.85rem}.mobile-workspace-page{padding:1rem 0 2rem;min-height:calc(100vh - 72px)}.mobile-workspace-container{padding:0 16px}.mobile-workspace-header{margin-bottom:1.5rem}.mobile-workspace-back{font-size:.85rem;margin-bottom:.75rem}.mobile-workspace-title{font-size:1.4rem}.mobile-workspace-subtitle{font-size:.9rem}.mobile-workspace-description{padding:.875rem 1rem}.mobile-workspace-description p{font-size:.85rem}.mobile-workspace-card{padding:1.25rem;border-radius:16px}.mobile-workspace-upload{padding:1.5rem;border-radius:12px;margin-bottom:1rem}.mobile-workspace-upload.has-image{padding:.75rem}.mobile-workspace-upload img{max-height:160px}.mobile-workspace-prompt{padding:12px 14px;font-size:16px;min-height:72px;margin-bottom:1rem}.mobile-workspace-btn{padding:14px 20px;font-size:1rem;border-radius:12px;min-height:48px}.mobile-workspace-progress{padding:1.5rem;margin:1rem 0}.mobile-workspace-result-actions{flex-direction:column;gap:10px;margin-top:1rem}.mobile-workspace-result-actions .btn{width:100%;min-height:44px}.mobile-workspace-error{padding:12px 14px;font-size:.9rem}}@media(max-width:380px){.mobile-capture-title{font-size:1.35rem}.mobile-capture-card-inner,.mobile-workspace-card{padding:1rem}}.serial-hint{padding:12px 16px;background:#f472b614;border:1px solid rgba(244,114,182,.2);border-radius:12px;margin-bottom:1.5rem}.serial-hint p{margin:0;font-size:.9rem;color:#94a3b8;line-height:1.6}.serial-hint p strong{color:#e2e8f0}.serial-progress .mobile-workspace-progress-fill,.serial-progress-fill{background:linear-gradient(90deg,#f472b6,#fbbf24)}.serial-btn{background:linear-gradient(135deg,#f472b6,#fbbf24)!important;padding:16px 24px!important}.serial-result{margin-top:1rem}.serial-result-title{font-size:1.25rem;color:#f8fafc;margin-bottom:1.5rem;text-align:center}.serial-result-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.serial-result-item{background:#0f172acc;border:1px solid rgba(148,163,184,.12);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;align-items:center}.serial-result-label{font-size:.8rem;color:#94a3b8;padding:8px 0}.serial-result-item img{width:100%;height:auto;display:block}.serial-download-btn{padding:8px 16px;margin:0 auto 12px;font-size:.85rem}.serial-result-actions{display:flex;justify-content:center}.serial-add-next{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(148,163,184,.12)}.serial-add-title{font-size:1rem;color:#e2e8f0;margin-bottom:1rem}.serial-extra-upload{min-height:100px}.serial-extra-previews{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.serial-extra-previews img{max-width:80px;max-height:80px;object-fit:cover;border-radius:8px}@media(max-width:768px){.serial-result-grid{grid-template-columns:1fr}}.stepbystep-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.stepbystep-modal{background:#0f172afa;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:1.5rem;max-width:90vw;max-height:90vh;overflow-y:auto}.stepbystep-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.stepbystep-modal-header h3{margin:0;color:#f8fafc;font-size:1.25rem}.stepbystep-modal-status{color:#10b981;font-size:.9rem}.stepbystep-modal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stepbystep-modal-slot{background:#0f172acc;border:1px solid rgba(148,163,184,.12);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;align-items:center;min-height:140px}.stepbystep-slot-label{font-size:.8rem;color:#94a3b8;padding:8px 0}.stepbystep-modal-slot img{width:100%;height:auto;display:block}.stepbystep-slot-loading,.stepbystep-slot-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;color:#94a3b8;font-size:.9rem}.stepbystep-slot-loading p,.stepbystep-slot-placeholder span{margin:0}@media(max-width:768px){.stepbystep-modal-grid{grid-template-columns:1fr}}.stepbystep-version-toggle{display:flex;gap:8px;margin-top:1rem}.stepbystep-version-btn{padding:8px 16px;border-radius:8px;border:1px solid rgba(148,163,184,.3);background:#0f172a99;color:#94a3b8;font-size:.9rem;cursor:pointer;transition:all .2s}.stepbystep-version-btn:hover{border-color:#10b98180;color:#e2e8f0}.stepbystep-version-btn.active{border-color:#10b981;background:#10b98126;color:#10b981}.stepbystep2-uploads{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stepbystep2-upload-block{display:flex;flex-direction:column;gap:8px}.serial-result-grid.single{grid-template-columns:1fr;max-width:600px;margin-left:auto;margin-right:auto}@media(max-width:768px){.stepbystep2-uploads{grid-template-columns:1fr}}.modal-backdrop{position:fixed;inset:0;background:#0a0f0de6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-close{position:absolute;top:16px;right:16px;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-secondary);transition:all var(--transition-fast);z-index:10}.modal-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.modal-header{padding:24px 24px 0;text-align:center}.modal-header h2{font-size:1.5rem;margin-bottom:8px}.modal-header p{color:var(--text-muted)}.modal-body{padding:24px}.source-photo{display:flex;gap:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius-lg);margin-bottom:20px}.source-image{width:100px;height:100px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}.source-image img{width:100%;height:100%;object-fit:cover}.source-info{display:flex;flex-direction:column;justify-content:center;gap:4px;overflow:hidden}.source-label{font-size:.85rem;color:var(--text-muted)}.source-name{font-weight:600;color:var(--text-primary);word-break:break-word}.prompt-section{margin-bottom:20px}.prompt-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:4px}.prompt-hint{font-size:.8rem;color:var(--accent-primary);margin-bottom:10px;padding:8px 12px;background:#00c85314;border-radius:var(--radius-sm);border-left:3px solid var(--accent-primary)}.prompt-input{width:100%;padding:14px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;line-height:1.5;resize:vertical;transition:border-color var(--transition-fast)}.prompt-input:focus{border-color:var(--accent-primary);outline:none}.prompt-input::placeholder{color:var(--text-dim)}.prompt-input:disabled{opacity:.6;cursor:not-allowed}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ff52521a;border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);margin-bottom:20px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.modal-actions .btn{min-width:140px}.result-section{text-align:center}.result-image{max-width:100%;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-tertiary);margin-bottom:20px}.result-image img{width:100%;height:auto;display:block}.result-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--text-muted)}.result-info{margin-bottom:20px}.result-info h3{color:var(--accent-primary);margin-bottom:8px}.result-prompt{color:var(--text-secondary);font-size:.9rem}.result-size{color:var(--text-muted);font-size:.85rem;margin-top:4px}.quality-selector{margin-bottom:20px}.quality-label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.quality-options{display:flex;gap:12px}.quality-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal)}.quality-option:hover:not(:disabled){border-color:var(--border-light);background:var(--bg-card-hover)}.quality-option.active{border-color:var(--accent-primary);background:#00c8531a}.quality-option:disabled{opacity:.5;cursor:not-allowed}.quality-value{font-weight:700;font-size:1.1rem;color:var(--text-primary)}.quality-desc{font-size:.8rem;color:var(--text-secondary)}.quality-speed{font-size:.7rem;color:var(--text-muted);padding:2px 8px;background:var(--bg-card);border-radius:4px}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.generation-progress{text-align:center;padding:40px 20px;background:linear-gradient(135deg,#00c8530d,#00963c0d);border-radius:var(--radius-lg);border:1px solid rgba(0,200,83,.2)}.progress-animation{position:relative;display:flex;justify-content:center;align-items:center;height:80px;margin-bottom:24px}.progress-circles{position:absolute;display:flex;gap:8px}.progress-circle{width:12px;height:12px;background:var(--accent-primary);border-radius:50%;box-shadow:0 0 20px var(--accent-primary)}.progress-icon{color:var(--accent-primary);filter:drop-shadow(0 0 10px var(--accent-primary));animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{transform:scale(1);filter:drop-shadow(0 0 10px var(--accent-primary))}50%{transform:scale(1.1);filter:drop-shadow(0 0 20px var(--accent-primary))}}.progress-bar-container{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-bottom:16px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:3px;transition:width .3s ease-out;box-shadow:0 0 10px var(--accent-primary)}.progress-stage{font-size:1rem;color:var(--text-primary);margin-bottom:8px;font-weight:500}.progress-percent{font-size:2rem;font-weight:700;color:var(--accent-primary);margin-bottom:8px;font-family:var(--font-heading)}.progress-time{font-size:.85rem;color:var(--text-muted)}@media(max-width:600px){.modal-content{max-height:100vh;border-radius:0}.source-photo{flex-direction:column;align-items:center;text-align:center}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-background{position:absolute;inset:0;z-index:0}.bg-gradient{position:absolute;inset:0;background:linear-gradient(135deg,#0a0f0a,#1a2f1a,#0d1f0d,#152515,#0a0f0a)}.bg-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(76,175,80,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(139,195,74,.08) 0%,transparent 40%),radial-gradient(circle at 40% 40%,rgba(76,175,80,.05) 0%,transparent 30%)}.login-container{position:relative;z-index:1;background:#141e14f2;border:1px solid rgba(76,175,80,.3);border-radius:20px;padding:3rem 2.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #00000080,0 0 40px #4caf501a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-logo{text-align:center;margin-bottom:2.5rem}.logo-icon{font-size:3.5rem;display:block;margin-bottom:.5rem;filter:drop-shadow(0 0 20px rgba(76,175,80,.5))}.login-logo h1{font-family:Manrope,sans-serif;font-size:2.5rem;font-weight:800;color:#4caf50;margin:0;letter-spacing:-1px}.logo-subtitle{font-size:1rem;color:#ffffff80;margin:.25rem 0 0;font-weight:500}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;color:#ffffffb3;font-weight:500}.form-group input{background:#0000004d;border:1px solid rgba(76,175,80,.3);border-radius:12px;padding:1rem 1.25rem;font-size:1rem;color:#fff;transition:all .3s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf5033;background:#0006}.form-group input::placeholder{color:#ffffff4d}.login-error{background:#f4433626;border:1px solid rgba(244,67,54,.3);color:#ff6b6b;padding:.75rem 1rem;border-radius:10px;font-size:.875rem;text-align:center}.login-button{background:linear-gradient(135deg,#4caf50,#66bb6a);border:none;border-radius:12px;padding:1rem 2rem;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .3s ease;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 20px #4caf504d}.login-button:hover:not(:disabled){box-shadow:0 6px 30px #4caf5066}.login-button:disabled{opacity:.6;cursor:not-allowed}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.login-footer p{color:#fff6;font-size:.8rem;margin:0}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0f0a,#1a2f1a);color:#fff}.loading-spinner{font-size:4rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.app-loading p{margin-top:1rem;color:#fff9}@media(max-width:480px){.login-container{margin:1rem;padding:2rem 1.5rem}.login-logo h1{font-size:2rem}.logo-icon{font-size:3rem}}.mobile-assistant-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#ff9a8b,#feca7a);color:#1a1a1d;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #ff9a8b66;z-index:999;transition:transform .2s,box-shadow .2s}.mobile-assistant-fab:hover{transform:scale(1.05);box-shadow:0 6px 28px #ff9a8b80}.mobile-assistant-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.mobile-assistant-dialog{background:#151d24;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:28px 24px;max-width:360px;width:100%;box-shadow:0 8px 40px #00000080;text-align:center}.mobile-assistant-robot-wrap{margin-bottom:20px}.mobile-assistant-robot{width:80px;height:80px;margin:0 auto;display:block}.mobile-assistant-dialog-title{margin:0 0 12px;font-size:1.15rem;font-weight:600;color:#ffb5a7;line-height:1.4}.mobile-assistant-dialog-text{color:#94a3b8;font-size:.95rem;line-height:1.6;margin:0 0 20px}.mobile-assistant-dialog-close{width:100%;padding:12px 20px;background:#ff9a8b33;border:1px solid rgba(255,154,139,.4);border-radius:10px;color:#ffb5a7;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.mobile-assistant-dialog-close:hover{background:#ff9a8b4d}.app{min-height:100vh;display:flex;flex-direction:column;min-width:0;overflow-x:hidden}.main-content{flex:1;padding:24px 0}.app-mobile .main-content{background:#08080a}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);color:var(--text-primary)}.app-loading .loading-spinner{font-size:4rem;animation:pulse 1.5s ease-in-out infinite}.app-loading p{margin-top:1rem;color:var(--text-secondary);font-size:1rem}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}
