*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-deep: #0a0a0f;--bg-primary: #1a1a2e;--bg-secondary: #1f1f3a;--bg-card: #16213e;--bg-elevated: #232345;--bg-hover: #2d2d55;--glass-bg: rgba(255, 255, 255, .08);--glass-border: rgba(255, 255, 255, .15);--glass-bg-hover: rgba(255, 255, 255, .12);--text-primary: #f0f0f5;--text-secondary: #9898b0;--text-muted: #6b6b85;--accent-primary: #7c3aed;--accent-secondary: #a855f7;--accent-pink: #ec4899;--accent-gradient: linear-gradient(135deg, #6366f1, #8b5cf6, #a855f7);--accent-gradient-warm: linear-gradient(135deg, #8b5cf6, #ec4899);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--space-2xs: .125rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px rgba(124, 58, 237, .15);--font-primary: "Inter", "Outfit", system-ui, sans-serif;--font-display: "Outfit", "Inter", system-ui, sans-serif;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.16, 1, .3, 1);--topbar-height: 56px;--panel-width: 320px}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);background-color:var(--bg-deep);color:var(--text-primary);line-height:1.5;overflow-x:hidden;min-height:100vh}.hidden{display:none!important}.gradient-text{background:var(--accent-gradient-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-bg{position:absolute;inset:0;z-index:0}.hero-grid{position:absolute;inset:-50%;width:200%;height:200%;background-image:linear-gradient(rgba(124,58,237,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.06) 1px,transparent 1px);background-size:60px 60px;animation:gridDrift 20s linear infinite}@keyframes gridDrift{0%{transform:translate(0) rotate(0)}to{transform:translate(60px,60px) rotate(1deg)}}.hero-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(600px circle at 30% 40%,rgba(124,58,237,.12),transparent 60%),radial-gradient(500px circle at 70% 60%,rgba(236,72,153,.08),transparent 60%),radial-gradient(400px circle at 50% 80%,rgba(99,102,241,.06),transparent 50%)}.hero-content{position:relative;z-index:1;text-align:center;padding:var(--space-xl);max-width:640px}.hero-badge{display:inline-block;padding:6px 16px;border-radius:var(--radius-full);background:#7c3aed1f;border:1px solid rgba(124,58,237,.25);color:var(--accent-secondary);font-size:.8rem;font-weight:500;letter-spacing:.5px;margin-bottom:var(--space-lg);animation:fadeInUp .8s ease both}.hero-title{font-family:var(--font-display);font-size:clamp(3.5rem,10vw,6rem);font-weight:900;line-height:1;letter-spacing:-2px;margin-bottom:var(--space-md);animation:fadeInUp .8s ease .15s both}.hero-title-line{display:block}.hero-subtitle{font-size:1.35rem;color:var(--text-secondary);font-weight:300;margin-bottom:var(--space-sm);animation:fadeInUp .8s ease .3s both}.hero-desc{font-size:.95rem;color:var(--text-muted);max-width:480px;margin:0 auto var(--space-2xl);line-height:1.7;animation:fadeInUp .8s ease .45s both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:1px solid transparent;border-radius:var(--radius-md);font-family:var(--font-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent-gradient);color:#fff;border:none;box-shadow:0 4px 16px #7c3aed4d}.btn-primary:hover:not(:disabled){box-shadow:0 6px 24px #7c3aed73;transform:translateY(-2px)}@keyframes generatingPulse{0%{box-shadow:0 0 #7c3aed66}70%{box-shadow:0 0 0 10px #7c3aed00}to{box-shadow:0 0 #7c3aed00}}.btn-generating{animation:generatingPulse 2s infinite;background:linear-gradient(135deg,#7c3aed,#4f46e5);cursor:wait!important;opacity:.9!important}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--glass-border);box-shadow:0 2px 8px #0003}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:#fff3;transform:translateY(-2px);box-shadow:0 6px 16px #00000059}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:var(--glass-bg);border-color:var(--glass-border);color:var(--text-primary)}.cropper-ratio-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 0 10px #7c3aed66}.btn-accent{background:var(--accent-primary);color:#fff;border:none}.btn-accent:hover{background:var(--accent-secondary)}.btn-option{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--glass-border);padding:6px 14px;font-size:.8rem}.btn-option.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-option:hover:not(.active){background:var(--bg-hover)}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem;font-weight:600}.btn-full{width:100%;justify-content:center}.btn-group{display:flex;gap:6px}.input{width:100%;padding:10px 14px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--glass-border);border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:.875rem;transition:border-color var(--transition-fast);outline:none}.input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #7c3aed26}.input-sm{padding:6px 10px;font-size:.8rem}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239898b0' viewBox='0 0 16 16'%3E%3Cpath d='m4.427 7.427 3.396 3.396a.25.25 0 0 0 .354 0l3.396-3.396A.25.25 0 0 0 11.396 7H4.604a.25.25 0 0 0-.177.427z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg-secondary);outline:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent-primary);box-shadow:0 0 8px #7c3aed66;cursor:pointer;transition:transform var(--transition-fast)}.slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-secondary);border-radius:24px;border:1px solid var(--glass-border);transition:var(--transition-base)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:2px;bottom:2px;background:var(--text-muted);border-radius:50%;transition:var(--transition-base)}.toggle-switch input:checked+.toggle-slider{background:var(--accent-primary);border-color:var(--accent-primary)}.toggle-switch input:checked+.toggle-slider:before{background:#fff;transform:translate(20px)}@keyframes errorBounce{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-4px)}}input.error-bounce,.input.error-bounce{animation:errorBounce .4s ease!important;border-color:var(--error)!important;box-shadow:0 0 0 3px #ef444433!important}.workspace{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-deep)}.topbar{display:flex;align-items:center;justify-content:space-between;min-height:var(--topbar-height);padding:0 var(--space-lg);background:var(--bg-primary);border-bottom:1px solid var(--glass-border);position:sticky;top:0;z-index:100}.topbar>div:first-child{flex:1;display:flex;justify-content:flex-start}.topbar-actions{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:6px}.topbar-brand{display:flex;align-items:center;gap:10px;cursor:pointer;transition:opacity var(--transition-fast)}.topbar-brand:hover{opacity:.8}.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;width:22px;height:22px}.mini-grid span{border-radius:2px;background:var(--accent-gradient);opacity:.8}.topbar-name{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:-.5px}.workspace-layout{display:flex;flex:1;height:calc(100vh - var(--topbar-height));overflow:hidden}.panel{height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--bg-hover) transparent}.panel::-webkit-scrollbar{width:6px}.panel::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:3px}.panel-left,.panel-right{width:var(--panel-width);min-width:var(--panel-width);background:var(--bg-primary);border-right:1px solid var(--glass-border);padding:var(--space-md);transition:width .3s ease,min-width .3s ease,padding .3s ease,opacity .3s ease;height:100%;overflow-y:auto}.panel-right{border-right:none;border-left:1px solid var(--glass-border)}.panel-left.collapsed,.panel-right.collapsed{width:0!important;min-width:0!important;padding:0!important;overflow:hidden;opacity:0;border:none}.resize-handle.collapsed{display:none}.panel-center{flex:1;display:flex;flex-direction:column;padding:var(--space-lg);background:var(--bg-deep);position:relative}.panel-section{margin-bottom:var(--space-lg)}.panel-title{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-md)}.sticky-section{position:sticky;top:0;background:var(--bg-primary);z-index:10;padding-top:var(--space-md);margin-top:calc(var(--space-md) * -1);padding-bottom:var(--space-md);border-bottom:1px solid var(--glass-border);margin-bottom:var(--space-md)}.action-section{position:sticky;bottom:0;background:var(--bg-primary);z-index:10;padding-top:var(--space-md);padding-bottom:var(--space-md);margin-bottom:0;border-top:1px solid var(--glass-border)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-size:.7rem;font-weight:700}.drop-zone{position:relative;border:2px dashed var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);overflow:hidden}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent-primary);background:#7c3aed14}.drop-zone.drag-over{border-style:solid;box-shadow:inset 0 0 40px #7c3aed33;transform:scale(1.02)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:var(--space-xl) var(--space-md);text-align:center;color:var(--text-muted)}.drop-zone-content p{font-size:.85rem;color:var(--text-secondary)}.drop-zone-hint{font-size:.75rem}.drop-zone-target{min-height:180px}.drop-zone-tiles{min-height:100px}.drop-zone-preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg)}.drop-zone-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#000000b3;color:#fff;border:1px solid rgba(255,255,255,.2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all var(--transition-fast);z-index:5}.drop-zone-remove:hover{background:var(--error);border-color:var(--error)}.drop-zone-edit{position:absolute;top:8px;right:44px;width:28px;height:28px;border-radius:50%;background:#000000b3;color:#fff;border:1px solid rgba(255,255,255,.2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all var(--transition-fast);z-index:5}.drop-zone-edit:hover{background:var(--accent-primary);border-color:var(--accent-primary)}.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:4px;margin-top:var(--space-sm);max-height:240px;overflow-y:auto}.tile-source-buttons{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-sm)}.btn-source{flex:1 1 40%;min-width:0;padding:5px 8px;font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;gap:4px;justify-content:center}.btn-source.btn-folder{flex:1 1 100%;order:1}.btn-source svg{flex-shrink:0;width:14px;height:14px}.tile-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:transform var(--transition-fast)}.tile-thumb:hover{transform:scale(1.05)}.tile-thumb img{width:100%;height:100%;object-fit:cover}.tile-thumb-remove{position:absolute;inset:0;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);font-size:1rem;border:none;cursor:pointer}.tile-thumb:hover .tile-thumb-remove{opacity:1}.unsplash-controls{display:flex;flex-direction:column;gap:8px;margin-bottom:var(--space-md)}.search-input-wrap{display:flex;gap:6px}.search-input-wrap .input{flex:1}.unsplash-api-row{opacity:.7}.unsplash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;max-height:300px;overflow-y:auto}.unsplash-item{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:transform var(--transition-fast)}.unsplash-item:hover{transform:scale(1.03)}.unsplash-item img{width:100%;height:100%;object-fit:cover}.unsplash-item-add{position:absolute;inset:0;background:#7c3aed99;color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);font-size:1.5rem;border:none;cursor:pointer}.unsplash-item:hover .unsplash-item-add{opacity:1}.unsplash-item.added .unsplash-item-add{opacity:1;background:#10b981b3;font-size:1.2rem}.unsplash-status{text-align:center;padding:var(--space-md);color:var(--text-muted);font-size:.8rem}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;width:100%;position:relative;overflow:hidden;min-height:0}.canvas-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);text-align:center;padding:var(--space-xl)}.canvas-placeholder p{font-size:1rem;color:var(--text-secondary)}.canvas-placeholder span{font-size:.8rem}.mosaic-canvas{display:block;margin:0 auto;border-radius:var(--radius-md);transition:transform .2s ease;image-rendering:auto;-webkit-image-rendering:auto}.canvas-wrapper{position:relative;flex:1;min-height:400px;border-radius:var(--radius-lg);background:var(--bg-primary);border:1px solid var(--glass-border);display:flex;flex-direction:column;padding-bottom:var(--space-md)}.panel-center{position:relative}.zoom-toolbar{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 16px;background:var(--bg-secondary);border-top:1px solid var(--glass-border);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.zoom-btn{background:var(--bg-deep);border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);display:flex;align-items:center;justify-content:center}.zoom-btn:hover{color:var(--accent-secondary);background:#6366f126}.zoom-slider-h{-webkit-appearance:none;appearance:none;width:180px;height:6px;background:var(--bg-deep);border-radius:3px;outline:none;cursor:pointer}.zoom-slider-h::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-secondary);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 0 4px #6366f166}.zoom-slider-h::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-secondary);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 0 4px #6366f166}.zoom-label{font-size:.75rem;font-weight:700;color:var(--accent-secondary);min-width:40px;text-align:center;white-space:nowrap}.zoom-separator{width:1px;height:20px;background:var(--glass-border);flex-shrink:0}.zoom-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.canvas-container.zoomable{cursor:grab}.canvas-container.panning{cursor:grabbing;-webkit-user-select:none;user-select:none}.progress-container{width:100%;max-width:500px;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0}.progress-bar{flex:1;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;width:0%;background:var(--accent-gradient);border-radius:3px;transition:width var(--transition-base);position:relative}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{font-size:.8rem;font-weight:600;color:var(--accent-secondary);min-width:36px}.progress-status{font-size:.75rem;color:var(--text-muted)}.canvas-actions{display:flex;gap:var(--space-sm);padding-top:var(--space-md)}.control-group{margin-bottom:var(--space-lg)}.control-label{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;color:var(--text-secondary);margin-bottom:var(--space-sm)}.control-value{font-weight:600;color:var(--accent-secondary);font-size:.85rem}.slider-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);margin-top:4px}.divider{border:none;border-top:1px solid var(--glass-border);margin:var(--space-lg) 0}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.stat{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-md);text-align:center}.stat-value{display:block;font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:2px}.stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.mobile-sheet{display:none}@media(max-width:1024px){.panel-right{display:none}.workspace-layout{flex-direction:column}.panel-left{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--glass-border)}.panel-center{min-height:50vh}}@media(max-width:768px){:root{--panel-width: 100%}.hero-title{font-size:3rem}.workspace-layout{flex-direction:column}.panel-left{max-height:none;overflow-y:visible}.canvas-container{min-height:250px}.canvas-actions{flex-direction:column;width:100%}.canvas-actions .btn{width:100%;justify-content:center}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.generating .btn-primary{animation:pulse 1.5s ease infinite}.tile-thumb{animation:tileAppear .3s ease both}@keyframes tileAppear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.mosaic-canvas.reveal{animation:canvasReveal .8s cubic-bezier(.16,1,.3,1) both}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes canvasReveal{0%{opacity:0;transform:scale(.95);filter:blur(10px)}to{opacity:1;transform:scale(1);filter:blur(0)}}.tile-source-buttons{display:flex;gap:5px;margin-top:var(--space-sm)}.btn-source{display:inline-flex;align-items:center;justify-content:center;gap:5px;flex:1;padding:7px 8px;background:var(--glass-bg);color:var(--text-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-family:var(--font-primary);font-size:.72rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap}.btn-source:hover{background:var(--glass-bg-hover);border-color:#ffffff26;color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-source:active{transform:translateY(0)}.btn-gdrive:hover{border-color:#4285f466;box-shadow:0 2px 12px #4285f426}.btn-onedrive:hover{border-color:#0078d466;box-shadow:0 2px 12px #0078d426}.tile-loading-status{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-top:var(--space-sm);background:#7c3aed14;border:1px solid rgba(124,58,237,.15);border-radius:var(--radius-sm);font-size:.78rem;color:var(--text-secondary);animation:fadeIn .3s ease}.loading-spinner-small{width:14px;height:14px;border:2px solid rgba(124,58,237,.2);border-top:2px solid var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cloud-config{display:flex;flex-direction:column;gap:8px}.config-group{display:flex;flex-direction:column;gap:3px}.config-label{font-size:.72rem;font-weight:500;color:var(--text-muted);letter-spacing:.3px}.config-hint{font-size:.68rem;color:var(--text-muted);opacity:.7;margin-top:4px;text-align:center}.highlight-pulse{animation:highlightPulse .6s ease 2}@keyframes highlightPulse{0%,to{box-shadow:none}50%{box-shadow:0 0 20px #7c3aed40,inset 0 0 20px #7c3aed0d}}.btn-info-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:transparent;border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-base);margin-left:auto;padding:0;flex-shrink:0}.btn-info-icon:hover{background:#7c3aed26;border-color:var(--accent-primary);color:var(--accent-secondary);transform:scale(1.1)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);animation:fadeIn .2s ease}.modal-content{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 60px #7c3aed14;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;animation:modalSlideIn .3s cubic-bezier(.16,1,.3,1);scrollbar-width:thin;scrollbar-color:var(--bg-hover) transparent}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--glass-border)}.modal-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text-primary)}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:transparent;border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.9rem}.modal-close:hover{background:var(--error);border-color:var(--error);color:#fff}.modal-body{padding:var(--space-lg) var(--space-xl)}.guide-section{margin-bottom:var(--space-md)}.guide-title{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.guide-steps{padding-left:1.4rem;display:flex;flex-direction:column;gap:6px}.guide-steps li{font-size:.82rem;color:var(--text-secondary);line-height:1.5}.guide-steps li::marker{color:var(--accent-primary);font-weight:700}.guide-steps a{color:var(--accent-secondary);text-decoration:none;border-bottom:1px solid rgba(168,85,247,.3);transition:border-color var(--transition-fast)}.guide-steps a:hover{border-color:var(--accent-secondary)}.guide-steps code{background:var(--bg-secondary);padding:1px 6px;border-radius:4px;font-size:.78rem;color:var(--accent-secondary)}.guide-steps strong{color:var(--text-primary)}.guide-divider{border:none;border-top:1px solid var(--glass-border);margin:var(--space-md) 0}.guide-tip{padding:10px 14px;background:#10b98114;border:1px solid rgba(16,185,129,.15);border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-secondary);line-height:1.5;margin-top:var(--space-md)}.guide-tip strong{color:var(--success)}.tooltip-inner{background:var(--bg-hover)!important;color:var(--text-primary)!important;font-family:var(--font-primary)!important;font-size:.75rem!important;border:1px solid var(--glass-border)!important;border-radius:var(--radius-sm)!important;padding:4px 8px!important;box-shadow:var(--shadow-md)!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.glow-effect{position:absolute;inset:0;border-radius:inherit;box-shadow:0 0 15px #7c3aed66;opacity:0;transition:opacity .3s ease;pointer-events:none}.drop-zone:hover .glow-effect,.btn-primary:hover .glow-effect{opacity:1}.lang-switcher{position:relative}.lang-toggle{display:flex;align-items:center;gap:6px;font-size:.8rem;padding:6px 10px;white-space:nowrap}.lang-chevron{opacity:.5;transition:transform .2s}.lang-dropdown:not(.hidden)~.lang-toggle .lang-chevron,.lang-switcher:has(.lang-dropdown:not(.hidden)) .lang-chevron{transform:rotate(180deg)}.lang-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;background:#1e202cf2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 12px 32px #0006;padding:4px;z-index:1000;animation:langDropIn .15s ease-out}@keyframes langDropIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.lang-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:.8rem;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;text-align:left}.lang-option:hover{background:#ffffff14;color:var(--text-primary)}.lang-option.active{background:linear-gradient(135deg,#6366f126,#a855f71a);color:var(--primary);font-weight:500}.lang-option.active:after{content:"✓";margin-left:auto;font-size:.7rem;color:var(--primary)}.font-scale-controls{display:flex;align-items:center;gap:2px;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-md);padding:2px}.font-scale-btn{font-weight:600;font-size:.75rem!important;padding:4px 8px!important;min-width:32px;border-radius:var(--radius-sm)!important}.font-scale-btn:hover{background:#ffffff14}.font-scale-label{font-size:.7rem;color:var(--text-secondary);min-width:36px;text-align:center;font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none}.resize-handle{position:relative;width:6px;flex-shrink:0;cursor:col-resize;background:var(--glass-border);transition:background var(--transition-fast),width var(--transition-fast);z-index:10;display:flex;align-items:center;justify-content:center}.resize-handle:before{content:"";position:absolute;inset:0 -4px;z-index:1}.resize-handle:hover,.resize-handle.active{width:6px;background:var(--accent-primary);box-shadow:0 0 12px #7c3aed4d}.resize-grip{display:flex;flex-direction:column;gap:3px;opacity:0;transition:opacity var(--transition-fast)}.resize-handle:hover .resize-grip,.resize-handle.active .resize-grip{opacity:1}.resize-grip span{display:block;width:4px;height:4px;border-radius:50%;background:#ffffffb3}body:has(.resize-handle.active){-webkit-user-select:none;user-select:none;cursor:col-resize}.dup-review-panel{margin-top:var(--space-sm);padding:10px 12px;background:#fbbf240f;border:1px solid rgba(251,191,36,.2);border-radius:var(--radius-md);animation:fadeIn .3s ease}.dup-review-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#fbbf24}.dup-review-header svg{flex-shrink:0;stroke:#fbbf24}.dup-review-count{font-size:.78rem;font-weight:600;color:var(--text-secondary)}.sim-threshold-ctrl{display:flex;align-items:center;gap:6px;margin:6px 0 4px}.sim-threshold-title{font-size:.7rem;color:var(--text-muted);margin-right:2px}.sim-thresh-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;font-size:.85rem;font-weight:700;border-radius:4px;border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.sim-thresh-btn:hover{background:#6366f133;color:var(--accent-secondary);border-color:var(--accent-secondary)}.sim-threshold-val{font-size:.8rem;font-weight:700;color:var(--accent-secondary);min-width:20px;text-align:center}.dup-review-actions{display:flex;gap:6px;flex-wrap:wrap}.dup-review-actions .btn{font-size:.72rem;padding:5px 10px}.dup-review-groups{margin-top:10px;display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--bg-hover) transparent;animation:dupGroupsSlideIn .3s ease}@keyframes dupGroupsSlideIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}.dup-group{padding:8px;background:#ffffff08;border:1px solid var(--glass-border);border-radius:var(--radius-sm)}.dup-group-label{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:.72rem;color:var(--text-muted)}.dup-reason-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:10px;font-size:.65rem;font-weight:600;letter-spacing:.3px}.dup-exact .dup-reason-badge{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.2)}.dup-similar .dup-reason-badge{background:#fbbf241f;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.dup-group-tiles{display:flex;gap:6px;flex-wrap:wrap}.dup-tile{position:relative;width:56px;height:56px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid transparent;transition:all var(--transition-fast)}.dup-tile img{width:100%;height:100%;object-fit:cover}.dup-best{border-color:#10b981;box-shadow:0 0 8px #10b98140}.dup-removable{border-color:#ef444459;opacity:.7}.dup-removable:hover{opacity:1}.dup-best-badge{position:absolute;bottom:0;left:0;right:0;background:#10b981d9;color:#fff;font-size:.58rem;font-weight:600;text-align:center;padding:1px 0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dup-keep-btn{position:absolute;bottom:0;left:0;right:0;background:#6366f1d9;color:#fff;font-size:.58rem;font-weight:600;text-align:center;padding:2px 0;border:none;cursor:pointer;opacity:0;transition:opacity var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dup-tile:hover .dup-keep-btn{opacity:1}.tile-upload-progress{margin:var(--space-sm) 0;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);animation:fadeInUp .3s ease both}.tile-upload-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.tile-upload-status{font-size:.8rem;color:var(--text-secondary)}.tile-upload-percent{font-size:.8rem;font-weight:700;color:var(--accent-secondary)}.tile-upload-bar{height:6px;background:var(--bg-deep);border-radius:3px;overflow:hidden}.tile-upload-fill{height:100%;width:0%;background:var(--accent-gradient);border-radius:3px;transition:width .15s ease;position:relative}.tile-upload-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}.auth-container{display:flex;align-items:center}.topbar-divider{width:1px;height:24px;background-color:var(--glass-border);margin:0 10px}.user-info-wrapper{position:relative}.user-profile-btn{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius-full)}.user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;background-color:var(--bg-hover)}.user-name{font-size:.85rem;font-weight:500;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-xs);min-width:150px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all var(--transition-fast);z-index:200}.user-info-wrapper:hover .user-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.btn-glow{box-shadow:0 0 10px #7c3aed33}.btn-glow:hover{box-shadow:0 0 15px #7c3aed66}.btn.loading{position:relative;color:transparent!important;pointer-events:none}.btn.loading:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btnSpinner .8s linear infinite}@keyframes btnSpinner{to{transform:rotate(360deg)}}.history-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding-right:5px;scrollbar-width:thin;scrollbar-color:var(--bg-hover) transparent}.history-item{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-base);cursor:pointer}.history-item:hover{background:var(--glass-bg-hover);border-color:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0003,inset 0 0 0 1px #ffffff0d}.history-meta{display:flex;flex-direction:column;gap:6px}.history-title{font-weight:600;color:var(--text-primary);font-size:.95rem;font-family:var(--font-display)}.history-date{font-size:.75rem;color:var(--text-muted);letter-spacing:.2px}.empty-state,.error-state{text-align:center;padding:32px 24px;color:var(--text-muted);background:var(--glass-bg);border:1px dashed var(--glass-border);border-radius:var(--radius-lg);font-size:.9rem}.error-state{color:var(--error);border-color:rgba(2ef,68,68,.2);background:#ef44440d}cropper-grid::part(line){stroke:var(--primary);stroke-opacity:.8;stroke-width:1.5px;stroke-dasharray:5,5}cropper-crosshair::part(line){stroke:var(--primary);stroke-opacity:.9}
