:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .8);--bg-card-hover: rgba(31, 41, 55, .9);--bg-glass: rgba(255, 255, 255, .03);--bg-glass-border: rgba(255, 255, 255, .08);--bg-input: rgba(255, 255, 255, .05);--accent-primary: #6366f1;--accent-primary-hover: #818cf8;--accent-secondary: #8b5cf6;--accent-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a78bfa 100%);--accent-glow: rgba(99, 102, 241, .3);--success: #10b981;--success-bg: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--info: #3b82f6;--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-accent: #a78bfa;--border-color: rgba(255, 255, 255, .08);--border-color-hover: rgba(255, 255, 255, .15);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs: .75rem;--font-sm: .8125rem;--font-base: .875rem;--font-md: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-primary: #f5f7fb;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .9);--bg-card-hover: rgba(243, 244, 246, .95);--bg-glass: rgba(0, 0, 0, .02);--bg-glass-border: rgba(0, 0, 0, .06);--bg-input: rgba(0, 0, 0, .04);--accent-primary: #4f46e5;--accent-primary-hover: #6366f1;--accent-secondary: #7c3aed;--accent-gradient: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #8b5cf6 100%);--accent-glow: rgba(79, 70, 229, .2);--success-bg: rgba(16, 185, 129, .08);--warning-bg: rgba(245, 158, 11, .08);--danger-bg: rgba(239, 68, 68, .08);--text-primary: #111827;--text-secondary: #4b5563;--text-muted: #9ca3af;--text-accent: #6366f1;--border-color: rgba(0, 0, 0, .1);--border-color-hover: rgba(0, 0, 0, .18);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12)}[data-theme=light] body:before{background:radial-gradient(ellipse 80% 50% at 20% 20%,rgba(79,70,229,.04) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(124,58,237,.03) 0%,transparent 50%)}[data-theme=light] .nav-header{background:#ffffffd9}[data-theme=light] .nav-dropdown-menu{background:#fffffff7}[data-theme=light] .form-select option{background:#fff;color:#111827}[data-theme=light] ::-webkit-scrollbar-thumb{background:#00000026}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00000040}body,.nav-header,.card,.btn,.form-input,.form-select,.merch-scan-bar,.merch-filter-row,.merch-table-wrapper,.modal,.modal-overlay{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.theme-toggle{width:34px;height:34px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition-fast);padding:0}.theme-toggle:hover{color:var(--text-primary);border-color:var(--border-color-hover);background:var(--bg-card-hover);transform:scale(1.05)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 80% 50% at 20% 20%,rgba(99,102,241,.08) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(139,92,246,.06) 0%,transparent 50%);pointer-events:none;z-index:0}#app{position:relative;z-index:1}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}.nav-header{position:sticky;top:0;z-index:100;background:#0a0e17d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);padding:0 var(--space-8)}.nav-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;height:60px;gap:var(--space-8)}.nav-logo{font-size:var(--font-lg);font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px;display:flex;align-items:center;gap:var(--space-2)}.nav-logo svg{width:24px;height:24px}.nav-links{display:flex;gap:var(--space-1)}.nav-link{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:var(--font-base);font-weight:500;transition:all var(--transition-fast);cursor:pointer;border:none;background:none}.nav-link:hover{color:var(--text-primary);background:var(--bg-glass)}.nav-link.active{color:var(--text-primary);background:#6366f11f}.nav-dropdown{position:relative}.nav-dropdown-toggle{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-base);font-weight:500;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;display:flex;align-items:center;gap:4px}.nav-dropdown-toggle:hover,.nav-dropdown-toggle.has-active{color:var(--text-primary);background:var(--bg-glass)}.nav-dropdown-toggle .dd-arrow{font-size:10px;transition:transform var(--transition-fast)}.nav-dropdown:hover .dd-arrow{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:#111827f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-1);box-shadow:var(--shadow-lg),0 0 30px #0000004d;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all var(--transition-fast);z-index:200}.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.nav-dropdown-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-4);border:none;background:none;color:var(--text-secondary);font-size:var(--font-base);font-weight:500;font-family:var(--font-family);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);text-align:left;white-space:nowrap}.nav-dropdown-item:hover{color:var(--text-primary);background:#6366f11a}.nav-dropdown-item.active{color:var(--text-primary);background:#6366f11f}.nav-status{margin-left:auto;display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-muted)}.nav-status .dot{width:8px;height:8px;border-radius:50%;background:var(--danger)}.nav-status .dot.connected{background:var(--success);box-shadow:0 0 8px #10b98180}.page-container{max-width:1400px;margin:0 auto;padding:var(--space-8)}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--font-2xl);font-weight:700;letter-spacing:-.5px;margin-bottom:var(--space-2)}.page-subtitle{color:var(--text-secondary);font-size:var(--font-base)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border:1px solid transparent;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-base);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;line-height:1.5}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm),0 0 0 0 var(--accent-glow)}.btn-primary:hover{box-shadow:var(--shadow-md),var(--shadow-glow);filter:brightness(1.1)}.btn-secondary{background:var(--bg-glass);border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{border-color:var(--border-color-hover);background:var(--bg-card-hover)}.btn-danger{background:var(--danger-bg);border-color:#ef444433;color:var(--danger)}.btn-danger:hover{background:#ef444433;border-color:#ef444466}.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:var(--space-1) var(--space-2)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-glass)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-sm)}.btn-lg{padding:var(--space-3) var(--space-8);font-size:var(--font-md)}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm)}.btn-icon.sm{width:28px;height:28px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-base)}.card:hover{border-color:var(--border-color-hover)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--font-sm);font-weight:500;color:var(--text-secondary)}.form-input,.form-select{width:100%;padding:var(--space-2) var(--space-4);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-base);transition:border-color var(--transition-fast);outline:none}.form-input:focus,.form-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}.form-input::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-select option,select.form-input option{background:#1f2937;color:#f9fafb;padding:8px}[data-theme=light] .form-select option,[data-theme=light] select.form-input option{background:#fff;color:#1f2937}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-full);font-size:var(--font-xs);color:var(--text-accent);white-space:nowrap}.chip .chip-remove{width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:transparent;border:none;color:var(--text-accent);cursor:pointer;font-size:12px;line-height:1;padding:0;transition:all var(--transition-fast)}.chip .chip-remove:hover{background:#ef44444d;color:var(--danger)}.dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-8);text-align:center;transition:all var(--transition-base);cursor:pointer;position:relative;overflow:hidden}.dropzone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent-gradient);opacity:0;transition:opacity var(--transition-base)}.dropzone.drag-over{border-color:var(--accent-primary);background:#6366f10d}.dropzone.drag-over:before{opacity:.05}.dropzone-icon{font-size:48px;margin-bottom:var(--space-4);opacity:.5}.dropzone-text{font-size:var(--font-md);color:var(--text-secondary);margin-bottom:var(--space-2)}.dropzone-hint{font-size:var(--font-sm);color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-8);animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s cubic-bezier(.16,1,.3,1)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-color)}.modal-title{font-size:var(--font-lg);font-weight:600}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color)}.validation-product-group{margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4);background:#f59e0b0f;border:1px solid rgba(245,158,11,.15);border-radius:var(--radius-md)}.validation-product-name{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.validation-warning-list{list-style:none;padding:0;margin:0}.validation-warning-list li{font-size:var(--font-xs);color:var(--warning);padding:2px 0;line-height:1.5}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-3)}.image-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--border-color);cursor:grab;transition:all var(--transition-fast);background:var(--bg-glass)}.image-item:active{cursor:grabbing}.image-item:hover{border-color:var(--accent-primary)}.image-item.is-primary{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.image-item.drag-over{border-color:var(--success);transform:scale(1.05)}.image-item img{width:100%;height:100%;object-fit:cover}.image-item .primary-badge{position:absolute;top:4px;left:4px;background:var(--accent-gradient);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px}.image-item .remove-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;opacity:0;transition:opacity var(--transition-fast)}.image-item:hover .remove-btn{opacity:1}.image-item.dragging{opacity:.4}.assignment-badge{position:absolute;bottom:0;left:0;right:0;background:#6366f1d9;color:#fff;font-size:10px;font-weight:600;padding:3px 6px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-item.has-assignment{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-glow)}.assignment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.assignment-slot{position:relative;border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:var(--space-2);text-align:center;transition:all var(--transition-fast);background:var(--bg-glass);cursor:default}.assignment-slot.drag-over{border-color:var(--accent-primary);background:#6366f114;box-shadow:0 0 12px var(--accent-glow);transform:scale(1.02)}.assignment-slot.has-image{border-style:solid;border-color:var(--accent-primary);background:#6366f10d}.assignment-slot-preview{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--space-2);display:flex;align-items:center;justify-content:center;background:var(--bg-input)}.assignment-slot-preview img{width:100%;height:100%;object-fit:cover}.assignment-slot-empty{font-size:28px;opacity:.3}.assignment-slot-label{font-size:var(--font-xs);font-weight:600;color:var(--text-secondary);word-break:break-word;line-height:1.3;padding:2px 0}.assignment-slot-clear{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:#ef4444cc;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;opacity:0;transition:opacity var(--transition-fast)}.assignment-slot:hover .assignment-slot-clear{opacity:1}.assignment-slot-delete{position:absolute;bottom:4px;left:4px;width:22px;height:22px;border-radius:50%;background:#ef4444cc;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;opacity:0;transition:opacity var(--transition-fast);z-index:2}.assignment-slot:hover .assignment-slot-delete{opacity:1}.assignment-slot-delete:hover{background:#ef4444;transform:scale(1.1)}.queue-panel{position:fixed;bottom:0;right:0;width:400px;max-height:500px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-lg);z-index:200;display:flex;flex-direction:column;transform:translateY(calc(100% - 48px));transition:transform var(--transition-slow)}.queue-panel.expanded{transform:translateY(0)}.queue-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-5);cursor:pointer;border-bottom:1px solid var(--border-color);min-height:48px}.queue-panel-header h3{font-size:var(--font-base);font-weight:600;display:flex;align-items:center;gap:var(--space-2)}.queue-panel-body{overflow-y:auto;flex:1;padding:var(--space-3)}.queue-item{padding:var(--space-3) var(--space-4);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.queue-item-title{font-size:var(--font-sm);font-weight:500;margin-bottom:var(--space-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-item-progress{height:4px;background:var(--bg-input);border-radius:2px;overflow:hidden}.queue-item-progress-bar{height:100%;border-radius:2px;transition:width var(--transition-base);background:var(--accent-gradient)}.queue-item-progress-bar.done{background:var(--success)}.queue-item-progress-bar.error{background:var(--danger)}.queue-item-status{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-1)}.queue-position-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#6366f126;border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-full);font-size:11px;font-weight:600;color:var(--text-accent);white-space:nowrap;letter-spacing:.3px}.product-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-6);overflow:hidden;transition:all var(--transition-base)}.product-card:hover{border-color:var(--border-color-hover)}.product-card-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.product-card-header .product-title{flex:1;font-size:var(--font-md);font-weight:600}.product-card-header .product-title input{background:none;border:none;color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-md);font-weight:600;width:100%;outline:none;padding:var(--space-1) 0;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.product-card-header .product-title input:focus{border-bottom-color:var(--accent-primary)}.product-card-body{padding:var(--space-6)}.product-card-section{margin-bottom:var(--space-6)}.product-card-section:last-child{margin-bottom:0}.product-card-section-title{font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-3)}.option-editor-row{display:flex;flex-wrap:wrap;gap:var(--space-3) var(--space-6);padding:var(--space-3) var(--space-6);border-bottom:1px solid var(--border-color);background:#6366f108}.option-editor-group{display:flex;align-items:center;gap:var(--space-2)}.option-editor-name{font-size:var(--font-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.option-editor-tags{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1)}.option-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;background:#6366f11f;border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-full);font-size:12px;font-weight:500;color:var(--text-accent);white-space:nowrap;transition:all var(--transition-fast)}.option-tag:hover{background:#6366f133;border-color:#6366f166}.option-tag-remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border:none;background:transparent;color:var(--text-accent);cursor:pointer;font-size:10px;border-radius:50%;padding:0;opacity:.5;transition:all var(--transition-fast)}.option-tag-remove:hover{opacity:1;background:#ef44444d;color:var(--danger)}.option-tag-add{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px dashed var(--border-color);background:transparent;color:var(--text-muted);cursor:pointer;font-size:14px;font-weight:600;border-radius:50%;padding:0;transition:all var(--transition-fast)}.option-tag-add:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f114}.variant-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.variant-table th{text-align:left;padding:var(--space-2) var(--space-3);color:var(--text-muted);font-weight:500;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.variant-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.variant-table tr:hover td{background:var(--bg-glass)}.variant-table .variant-img-cell{width:40px}.variant-table .variant-img{width:36px;height:36px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border-color)}.variant-fullscreen-modal{max-width:90vw!important;width:90vw;max-height:90vh;display:flex;flex-direction:column}.variant-table-fullscreen{width:100%}.variant-table-fullscreen thead{position:sticky;top:0;z-index:2;background:var(--bg-secondary)}.variant-table-fullscreen th{padding:var(--space-3) var(--space-4)!important;font-size:var(--font-sm)!important}.variant-table-fullscreen td{padding:var(--space-2) var(--space-4)!important;font-size:var(--font-sm)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);font-size:var(--font-sm);margin-bottom:var(--space-4)}.alert-warning{background:var(--warning-bg);border:1px solid rgba(245,158,11,.2);color:var(--warning)}.alert-danger{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);color:var(--danger)}.alert-success{background:var(--success-bg);border:1px solid rgba(16,185,129,.2);color:var(--success)}.toggle-wrapper{display:flex;align-items:center;gap:var(--space-3)}.toggle{position:relative;width:40px;height:22px;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-input);border:1px solid var(--border-color);border-radius:11px;transition:all var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;top:2px;left:2px;background:var(--text-secondary);border-radius:50%;transition:all var(--transition-fast)}.toggle input:checked+.toggle-slider{background:var(--accent-primary);border-color:var(--accent-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(18px);background:#fff}.toggle-label{font-size:var(--font-sm);color:var(--text-secondary)}.ai-desc-toggle{display:flex;align-items:center;gap:5px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px;color:var(--text-secondary);transition:color var(--transition-fast)}.ai-desc-toggle-track{position:relative;width:34px;height:18px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:9px;transition:all var(--transition-fast);flex-shrink:0}.ai-desc-toggle-track.active{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.ai-desc-toggle-thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;background:var(--text-secondary);border-radius:50%;transition:all var(--transition-fast)}.ai-desc-toggle-track.active .ai-desc-toggle-thumb{transform:translate(16px);background:#fff}.ai-desc-toggle:hover .ai-desc-toggle-track:not(.active){border-color:var(--accent-primary)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-6)}.template-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base);cursor:pointer}.template-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.template-card-name{font-size:var(--font-md);font-weight:600;margin-bottom:var(--space-3)}.template-card-meta{font-size:var(--font-sm);color:var(--text-muted);margin-bottom:var(--space-4)}.template-card-options{display:flex;flex-wrap:wrap;gap:var(--space-2)}.template-card-actions{display:flex;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.toolbar{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-6);flex-wrap:wrap}.toolbar-section{display:flex;align-items:center;gap:var(--space-3)}.toolbar-divider{width:1px;height:24px;background:var(--border-color)}.option-block{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-4)}.option-block-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.option-block-header input{flex:1;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-base);padding:var(--space-1) var(--space-3);outline:none}.option-block-header input:focus{border-color:var(--accent-primary)}.option-add-value input{flex:1;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-sm);padding:var(--space-1) var(--space-3);outline:none}.option-add-value input:focus{border-color:var(--accent-primary)}.empty-state{text-align:center;padding:var(--space-12) var(--space-8);color:var(--text-muted)}.empty-state-icon{font-size:60px;margin-bottom:var(--space-4);opacity:.4}.empty-state-title{font-size:var(--font-lg);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--font-base);margin-bottom:var(--space-6)}.variant-count{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:#6366f11a;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600;color:var(--text-accent)}.variant-count.over-limit{background:var(--danger-bg);color:var(--danger)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s ease-in-out infinite}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.text-sm{font-size:var(--font-sm)}.text-muted{color:var(--text-muted)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.hidden{display:none!important}.range-wrapper{display:flex;align-items:center;gap:var(--space-3)}.range-wrapper input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--bg-input);border-radius:2px;outline:none}.range-wrapper input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-primary);cursor:pointer;border:2px solid white;box-shadow:var(--shadow-sm)}.range-value{font-size:var(--font-sm);font-weight:600;color:var(--text-accent);min-width:36px;text-align:right}.option-block{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-3);transition:all var(--transition-fast)}.option-block[draggable]{cursor:default}.option-block.dragging{opacity:.4;border-color:var(--accent-primary)}.option-block.drag-target{border-color:var(--success);background:#10b9810f;box-shadow:0 0 0 2px #10b98126}.option-block-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.option-block-header .option-name-input{flex:1}.option-values{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.option-add-value{display:flex;gap:var(--space-2)}.option-add-value input{flex:1}.drag-handle{cursor:grab;font-size:18px;color:var(--text-muted);-webkit-user-select:none;user-select:none;line-height:1;padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.drag-handle:hover{color:var(--text-primary);background:var(--bg-card-hover)}.drag-handle:active{cursor:grabbing}#status-counters{display:flex;gap:var(--space-2);flex-wrap:wrap}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500;color:var(--text-secondary);background:var(--bg-glass);border:1px solid var(--border-color);white-space:nowrap}.status-badge strong{font-weight:700;color:var(--text-primary)}.status-badge .status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-badge.preparing .status-dot{background:var(--info);box-shadow:0 0 5px #3b82f680}.status-badge.uploading .status-dot{background:var(--warning);box-shadow:0 0 5px #f59e0b80;animation:pulse-dot 1.2s ease-in-out infinite}.status-badge.done .status-dot{background:var(--success);box-shadow:0 0 5px #10b98180}.status-badge.error .status-dot{background:var(--danger);box-shadow:0 0 5px #ef444480}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-8);background:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(168,85,247,.06) 0%,transparent 50%),var(--bg-primary)}.login-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 60px #6366f10a;overflow:hidden;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.login-header{text-align:center;padding:var(--space-10) var(--space-8) var(--space-6)}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-lg);background:var(--accent-gradient);color:#fff;margin-bottom:var(--space-5)}.login-title{font-size:var(--font-xl);font-weight:700;letter-spacing:-.5px;margin-bottom:var(--space-2);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{font-size:var(--font-sm);color:var(--text-muted)}.login-form{padding:0 var(--space-8) var(--space-6)}.login-field{margin-bottom:var(--space-5)}.login-field label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2)}.login-field input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-base);outline:none;transition:all var(--transition-fast)}.login-field input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.login-field input::placeholder{color:var(--text-muted)}.login-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--danger);font-size:var(--font-sm);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);animation:fadeIn .2s ease}.login-btn{width:100%;padding:var(--space-3) var(--space-6);background:var(--accent-gradient);border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-family);font-size:var(--font-base);font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:44px}.login-btn:hover{opacity:.9;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-btn-loading{display:inline-flex;align-items:center}.login-footer{text-align:center;padding:var(--space-4) var(--space-8);border-top:1px solid var(--border-color);font-size:var(--font-xs);color:var(--text-muted)}.nav-user{display:flex;align-items:center;gap:var(--space-3);margin-left:var(--space-4);padding-left:var(--space-4);border-left:1px solid var(--border-color)}.nav-user-name{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);white-space:nowrap}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.products-history-summary{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-6)}.products-history-count{font-size:var(--font-base);color:var(--text-secondary)}.products-history-count strong{color:var(--text-accent)}.products-date-group{margin-bottom:var(--space-6)}.products-date-header{font-size:var(--font-md);font-weight:600;color:var(--text-primary);padding:var(--space-3) var(--space-4);background:#6366f114;border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.products-date-count{font-weight:400;color:var(--text-muted);font-size:var(--font-sm)}.products-history-table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card)}.products-history-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.products-history-table thead{background:#ffffff08}.products-history-table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:600;color:var(--text-secondary);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);white-space:nowrap}.products-history-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);vertical-align:middle}.products-history-row{transition:background var(--transition-fast)}.products-history-row:hover{background:#ffffff05}.products-history-row:last-child td{border-bottom:none}.products-history-img-cell{width:60px}.products-history-img{width:150px;height:auto;max-height:200px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color);display:block}.products-history-img-placeholder{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--bg-glass);border:1px dashed var(--border-color);border-radius:var(--radius-sm);font-size:20px;opacity:.5}.products-history-link{color:var(--text-accent);text-decoration:none;font-weight:500;transition:color var(--transition-fast);line-height:1.4;display:inline-block}.products-history-link:hover{color:var(--accent-primary-hover);text-decoration:underline}.products-history-title{color:var(--text-primary);font-weight:500;line-height:1.4}.products-history-id{font-size:11px;color:var(--text-muted);margin-top:4px;word-break:break-all}.products-history-user{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap}.products-history-store{font-size:var(--font-sm);color:var(--text-muted)}.products-history-time{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap}.status-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;white-space:nowrap}.status-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(16,185,129,.2)}.status-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.status-draft{background:var(--warning-bg);color:var(--warning);border:1px solid rgba(245,158,11,.2)}.status-unknown{background:var(--bg-glass);color:var(--text-muted);border:1px solid var(--border-color)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-icon{font-size:48px;margin-bottom:var(--space-4);opacity:.5}.spin-icon{font-size:32px;animation:spin 1.5s linear infinite;display:inline-block}.loading-spinner{animation:fadeIn .3s ease}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6) 0}.pagination-pages{display:flex;align-items:center;gap:var(--space-1)}.pagination-btn{min-width:36px;height:36px;padding:0 var(--space-2);border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.pagination-btn:hover{border-color:var(--accent-primary);color:var(--text-primary);background:#6366f11a}.pagination-btn.active{background:var(--accent-gradient);color:#fff;border-color:transparent;box-shadow:var(--shadow-glow)}.pagination-dots{padding:0 var(--space-2);color:var(--text-muted);font-size:var(--font-sm)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.product-actions-cell{white-space:nowrap}.btn-action{padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);font-size:11px;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family);margin-right:4px}.btn-action:hover{transform:translateY(-1px)}.btn-view{border-color:#6366f14d;color:var(--accent-primary)}.btn-view:hover{background:#6366f126;border-color:var(--accent-primary)}.btn-draft{border-color:#f59e0b4d;color:var(--warning)}.btn-draft:hover{background:#f59e0b26;border-color:var(--warning)}.btn-delete{border-color:#ef44444d;color:var(--danger)}.btn-delete:hover{background:#ef444426;border-color:var(--danger)}.btn-dismiss{border-color:#6b728066;color:#9ca3af}.btn-dismiss:hover{background:#6b728026;border-color:#9ca3af}.status-deleted{background:#ef444426!important;color:#ef4444!important;text-decoration:line-through}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:8px 20px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-family:var(--font-family)}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.modal-confirm{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-8);max-width:400px;width:90%;text-align:center;box-shadow:var(--shadow-heavy)}.modal-confirm-icon{font-size:48px;margin-bottom:var(--space-4)}.modal-confirm h3{color:var(--text-primary);margin-bottom:var(--space-2)}.modal-confirm p{color:var(--text-secondary);font-size:var(--font-sm);margin-bottom:var(--space-6)}.modal-confirm-btns{display:flex;gap:var(--space-3);justify-content:center}.modal-editor{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-heavy);overflow:hidden}.modal-editor-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-color)}.modal-editor-header h2{color:var(--text-primary);font-size:var(--font-lg);margin:0}.modal-close{background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{color:var(--text-primary);background:var(--bg-glass)}.modal-editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--text-muted)}.modal-editor-body{display:flex;flex:1;overflow:hidden}.modal-editor-left{flex:1;padding:var(--space-5);overflow-y:auto;display:flex;flex-direction:column}.modal-editor-right{width:280px;padding:var(--space-5);border-left:1px solid var(--border-color);background:#0000001a;display:flex;flex-direction:column;gap:var(--space-4);overflow-y:auto}.modal-section-title{color:var(--text-primary);font-size:var(--font-md);margin-bottom:var(--space-3)}.modal-label{display:block;font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}.modal-field{display:flex;flex-direction:column}.modal-select,.modal-input{width:100%;padding:8px 12px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-primary);font-size:var(--font-sm);font-family:var(--font-family);transition:border-color var(--transition-fast)}.modal-select:focus,.modal-input:focus{outline:none;border-color:var(--accent-primary)}.modal-select option{background:#1e1e2e;color:#e2e8f0}.collection-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;min-height:8px}.collection-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-full);background:#6366f126;border:1px solid rgba(99,102,241,.3);color:var(--text-accent);font-size:12px;font-weight:500;animation:fadeIn .2s ease}.collection-tag-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:11px;padding:0 2px;line-height:1;border-radius:50%;transition:all var(--transition-fast)}.collection-tag-remove:hover{color:var(--danger);background:#ef444426}.upload-collection-row{display:flex;align-items:center;gap:8px;padding:6px 16px;background:#ffffff05;border-bottom:1px solid var(--border-subtle)}.upload-col-tags{display:flex;flex-wrap:wrap;gap:4px;align-items:center;flex:1;min-height:24px}.btn-sync-collections{background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;padding:2px 6px;line-height:1;transition:all var(--transition-fast);color:var(--text-secondary)}.btn-sync-collections:hover{background:#6366f11a;border-color:var(--accent-primary)}.btn-add-collection{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px dashed var(--border-color-hover);border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:13px;line-height:1;color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0}.btn-add-collection:hover{background:#6366f11f;border-color:var(--accent-primary);color:var(--accent-primary-hover);transform:scale(1.08)}.create-col-seo-section{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.create-col-seo-header{font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-4);letter-spacing:.3px}.char-counter{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-1);text-align:right}#quill-editor-container{flex:1;min-height:300px;border-radius:0 0 var(--radius-md) var(--radius-md)}#quill-editor-container .ql-editor{min-height:300px;color:var(--text-primary);font-size:var(--font-sm)}.ql-toolbar.ql-snow{border-color:var(--border-color)!important;background:#ffffff08;border-radius:var(--radius-md) var(--radius-md) 0 0}.ql-container.ql-snow{border-color:var(--border-color)!important}.ql-toolbar .ql-stroke{stroke:var(--text-secondary)!important}.ql-toolbar .ql-fill{fill:var(--text-secondary)!important}.ql-toolbar .ql-picker-label{color:var(--text-secondary)!important}.ql-toolbar button:hover .ql-stroke{stroke:var(--accent-primary)!important}.ql-toolbar button:hover .ql-fill{fill:var(--accent-primary)!important}.desc-editor .ql-toolbar.ql-snow{border:1px solid var(--border-color);border-radius:var(--radius-md) var(--radius-md) 0 0;padding:4px 8px;background:#ffffff05}.desc-editor .ql-container.ql-snow{border:1px solid var(--border-color);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);font-size:var(--font-sm);min-height:80px;max-height:300px;overflow-y:auto}.desc-editor .ql-editor{min-height:80px;color:var(--text-primary);line-height:1.6;padding:var(--space-3) var(--space-4)}.desc-editor .ql-editor.ql-blank:before{color:var(--text-muted);font-style:italic}.desc-editor .ql-editor h2{color:var(--text-primary);font-size:var(--font-lg);margin-bottom:var(--space-2)}.desc-editor .ql-editor h3{color:var(--text-primary);font-size:var(--font-md);margin-bottom:var(--space-2)}.desc-editor .ql-editor p{margin-bottom:var(--space-2)}.desc-editor .ql-editor ul,.desc-editor .ql-editor ol{margin-bottom:var(--space-2);padding-left:var(--space-5)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mockup-page{max-width:1200px}.mockup-workspace{display:flex;align-items:stretch;gap:var(--space-6);margin-bottom:var(--space-8)}.mockup-panel{flex:1;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;display:flex;flex-direction:column;transition:border-color var(--transition-base)}.mockup-panel:hover{border-color:var(--border-color-hover)}.mockup-panel-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.mockup-panel-badge{width:32px;height:32px;min-width:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-gradient);color:#fff;font-weight:700;font-size:var(--font-base)}.mockup-panel-title{font-size:var(--font-md);font-weight:600;color:var(--text-primary);margin:0}.mockup-panel-desc{font-size:var(--font-xs);color:var(--text-muted);margin:2px 0 0}.mockup-dropzone{flex:1;padding:var(--space-4);cursor:pointer;min-height:280px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.mockup-dropzone.drag-over{background:#6366f10f}.mockup-dropzone-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8);border:2px dashed var(--border-color);border-radius:var(--radius-lg);width:100%;height:100%;min-height:240px;transition:all var(--transition-base)}.mockup-dropzone:hover .mockup-dropzone-inner{border-color:var(--accent-primary);background:#6366f108}.mockup-dropzone.drag-over .mockup-dropzone-inner{border-color:var(--accent-primary);background:#6366f114;box-shadow:0 0 20px var(--accent-glow)}.mockup-dropzone.has-image .mockup-dropzone-inner{border:none;padding:0}.mockup-dropzone-icon{font-size:48px;opacity:.5;line-height:1}.mockup-dropzone-text{font-size:var(--font-base);color:var(--text-secondary);font-weight:500}.mockup-dropzone-hint{font-size:var(--font-xs);color:var(--text-muted)}.mockup-preview-wrapper{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.mockup-preview-img{max-width:100%;max-height:300px;width:auto;height:auto;border-radius:var(--radius-md);object-fit:contain;box-shadow:var(--shadow-md)}.mockup-preview-remove{position:absolute;top:4px;right:4px;width:28px;height:28px;border-radius:50%;background:#ef4444d9;border:none;color:#fff;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mockup-preview-wrapper:hover .mockup-preview-remove{opacity:1}.mockup-preview-remove:hover{background:#ef4444;transform:scale(1.1)}.mockup-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) 0;flex-shrink:0}.mockup-arrow-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.mockup-arrow-icon svg{width:22px;height:22px}.mockup-arrow-label{font-size:var(--font-xl);font-weight:700;color:var(--text-muted)}.mockup-mode-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--space-5) var(--space-6);margin-bottom:var(--space-6)}.mockup-mode-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5)}.mockup-mode-options{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-4)}.mockup-mode-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-glass)}.mockup-mode-card:hover{border-color:var(--border-color-hover);background:var(--bg-card-hover)}.mockup-mode-card.active{border-color:var(--accent-primary);background:#6366f114;box-shadow:0 0 12px var(--accent-glow)}.mockup-mode-icon{font-size:24px;line-height:1;flex-shrink:0;margin-top:2px}.mockup-mode-info{flex:1;min-width:0}.mockup-mode-name{font-size:var(--font-base);font-weight:600;color:var(--text-primary);margin-bottom:2px}.mockup-mode-desc{font-size:var(--font-xs);color:var(--text-muted);line-height:1.4}.mockup-custom-prompt-wrapper{margin-top:var(--space-3);animation:fadeIn .2s ease}.mockup-custom-textarea{resize:vertical;min-height:60px;max-height:200px;font-size:var(--font-base);line-height:1.5}@media (max-width: 768px){.mockup-mode-options{grid-template-columns:1fr}}.mockup-actions{display:flex;justify-content:center;margin-bottom:var(--space-10)}.mockup-generate-btn{padding:var(--space-4) var(--space-12);font-size:var(--font-lg);font-weight:600;gap:var(--space-3);border-radius:var(--radius-full);position:relative;overflow:hidden}.mockup-generate-btn:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.mockup-generate-btn.generating{pointer-events:none}.mockup-generate-btn-icon{font-size:var(--font-xl);display:inline-flex;align-items:center}.mockup-spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:mockup-spin .7s linear infinite}@keyframes mockup-spin{to{transform:rotate(360deg)}}.mockup-result-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;animation:slideUp .35s cubic-bezier(.16,1,.3,1)}.mockup-result-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.mockup-result-title{font-size:var(--font-lg);font-weight:600;margin:0}.mockup-result-actions{display:flex;gap:var(--space-3)}.mockup-result-container{padding:var(--space-6);display:flex;align-items:center;justify-content:center;min-height:300px}.mockup-result-container img{max-width:100%;max-height:600px;width:auto;height:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);object-fit:contain}.mockup-cost-bar{display:flex;align-items:center;justify-content:center;gap:var(--space-6);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);background:#6366f10a}.mockup-cost-item{display:flex;flex-direction:column;align-items:center;gap:2px}.mockup-cost-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.mockup-cost-value{font-size:var(--font-base);font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.mockup-cost-highlight{color:var(--success)}.mockup-cost-divider{width:1px;height:32px;background:var(--border-color)}@media (max-width: 768px){.mockup-workspace{flex-direction:column}.mockup-arrow{flex-direction:row;padding:0 var(--space-4)}.mockup-arrow-icon svg{transform:rotate(90deg)}.mockup-generate-btn{width:100%}.mockup-result-header{flex-direction:column;gap:var(--space-3);align-items:flex-start}}.nav-hamburger{display:none;width:36px;height:36px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-glass);color:var(--text-secondary);font-size:20px;cursor:pointer;align-items:center;justify-content:center;transition:all var(--transition-fast);padding:0;line-height:1}.nav-hamburger:hover{color:var(--text-primary);border-color:var(--border-color-hover);background:var(--bg-card-hover)}@media (max-width: 1024px){.nav-inner{gap:var(--space-4)}.nav-link,.nav-dropdown-toggle{padding:var(--space-2) var(--space-3);font-size:var(--font-sm)}.page-container{padding:var(--space-6)}.mockup-workspace{gap:var(--space-4)}.modal-editor-right{width:240px}.products-history-img{width:100px}}@media (max-width: 768px){.nav-hamburger{display:flex}.nav-inner{flex-wrap:wrap;height:auto;padding:var(--space-3) 0;gap:var(--space-2)}.nav-logo{font-size:var(--font-base)}.nav-links{display:none;width:100%;flex-direction:column;gap:var(--space-1);padding-top:var(--space-2);border-top:1px solid var(--border-color);order:10}.nav-links.open{display:flex}.nav-link{width:100%;text-align:left;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm)}.nav-dropdown{width:100%}.nav-dropdown-toggle{width:100%;justify-content:space-between;padding:var(--space-2) var(--space-4)}.nav-dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;padding:0 0 0 var(--space-6);min-width:auto}.nav-dropdown-item{padding:var(--space-2) var(--space-4)}.nav-status{margin-left:0;font-size:var(--font-xs);order:2}.nav-user{margin-left:auto;padding-left:0;border-left:none;gap:var(--space-2)}.nav-user-name{display:none}.nav-header{padding:0 var(--space-4)}.page-container{padding:var(--space-4)}.page-title{font-size:var(--font-xl)}.queue-panel{width:100%;left:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.product-card-header{flex-wrap:wrap;gap:var(--space-2);padding:var(--space-4)}.product-card-body{padding:var(--space-4)}.variant-table{font-size:var(--font-xs)}.variant-table th,.variant-table td{padding:var(--space-1) var(--space-2)}.image-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-2)}.assignment-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-2)}.option-editor-row{padding:var(--space-2) var(--space-4);gap:var(--space-2)}.toolbar{padding:var(--space-3) var(--space-4);gap:var(--space-2)}.toolbar-divider{display:none}.template-grid{grid-template-columns:1fr;gap:var(--space-4)}.modal-overlay{padding:var(--space-3)}.modal{max-width:100%;max-height:90vh;border-radius:var(--radius-lg)}.modal-header,.modal-body,.modal-footer{padding:var(--space-4)}.modal-editor{width:100%;max-width:100%;max-height:95vh}.modal-editor-body{flex-direction:column}.modal-editor-right{width:100%;border-left:none;border-top:1px solid var(--border-color)}.modal-editor-header{padding:var(--space-3) var(--space-4)}.variant-fullscreen-modal{max-width:100vw!important;width:100vw;max-height:100vh;border-radius:0}.products-history-summary{flex-direction:column;gap:var(--space-3);align-items:flex-start;padding:var(--space-4)}.products-history-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.products-history-table{min-width:600px}.products-history-img{width:80px;max-height:100px}.product-actions-cell{display:flex;flex-wrap:wrap;gap:4px}.btn-action{margin-right:0}.pagination{flex-wrap:wrap}.pagination-pages{flex-wrap:wrap;justify-content:center}.card-header{padding:var(--space-4);flex-wrap:wrap;gap:var(--space-2)}.card-body{padding:var(--space-4)}.dropzone{padding:var(--space-8) var(--space-4)}.dropzone-icon{font-size:36px}.login-wrapper{padding:var(--space-4)}.login-header{padding:var(--space-6) var(--space-4) var(--space-4)}.login-form{padding:0 var(--space-4) var(--space-4)}.login-footer{padding:var(--space-3) var(--space-4)}.mockup-mode-options{grid-template-columns:1fr}.mockup-cost-bar{flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.mockup-cost-divider{display:none}#status-counters{gap:var(--space-1)}.status-badge{padding:3px 8px;font-size:10px}.empty-state{padding:var(--space-8) var(--space-4)}.empty-state-icon,.empty-icon{font-size:40px}.modal-confirm{padding:var(--space-6);width:95%}.upload-collection-row{flex-wrap:wrap;gap:6px;padding:var(--space-2) var(--space-3)}}@media (max-width: 480px){.page-container{padding:var(--space-3)}.page-title{font-size:var(--font-lg)}.page-subtitle{font-size:var(--font-xs)}.btn{padding:var(--space-2) var(--space-3);font-size:var(--font-sm)}.btn-lg{padding:var(--space-2) var(--space-5);font-size:var(--font-base)}.form-input,.form-select{font-size:var(--font-sm);padding:var(--space-2) var(--space-3)}.product-card-header,.product-card-body{padding:var(--space-3)}.product-card-header .product-title input{font-size:var(--font-base)}.image-grid{grid-template-columns:repeat(auto-fill,minmax(65px,1fr))}.assignment-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.template-card{padding:var(--space-4)}.login-card{border-radius:var(--radius-lg)}.login-logo{width:52px;height:52px}.login-title{font-size:var(--font-lg)}.modal-overlay{padding:var(--space-2)}.modal-title{font-size:var(--font-base)}.mockup-dropzone{min-height:200px}.mockup-dropzone-inner{min-height:180px;padding:var(--space-4)}.mockup-dropzone-icon{font-size:36px}.mockup-generate-btn{padding:var(--space-3) var(--space-6);font-size:var(--font-base)}.mockup-preview-img{max-height:200px}}.email-action-btn:hover{background:#3b82f61a!important;border-color:#3b82f6!important;color:#3b82f6!important;transform:translateY(-1px)}.email-action-btn:active{transform:scale(.96)}.thread-reply-btn:hover{background:#3b82f61f!important;border-color:#3b82f6!important;color:#3b82f6!important}.compose-panel{animation:slideUp .2s ease}.compose-panel .form-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #6366f11f}.compose-panel .ql-toolbar.ql-snow{border:none;border-bottom:1px solid var(--border-color);background:var(--bg-glass);padding:4px 8px}.compose-panel .ql-container.ql-snow{border:none;font-family:var(--font-family);font-size:13px}.compose-panel .ql-editor{color:var(--text-primary);line-height:1.7;padding:10px 14px;min-height:120px}.compose-panel .ql-editor.ql-blank:before{color:var(--text-muted);font-style:normal}.compose-panel .ql-snow .ql-stroke{stroke:var(--text-secondary)}.compose-panel .ql-snow .ql-fill,.compose-panel .ql-snow .ql-stroke.ql-fill{fill:var(--text-secondary)}.compose-panel .ql-snow .ql-picker{color:var(--text-secondary)}.compose-panel .ql-snow .ql-picker-options{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.compose-panel .ql-snow .ql-picker-label:hover,.compose-panel .ql-snow .ql-picker-item:hover{color:var(--accent-primary)}.compose-panel .ql-toolbar.ql-snow button:hover .ql-stroke,.compose-panel .ql-toolbar.ql-snow button.ql-active .ql-stroke{stroke:var(--accent-primary)}.compose-panel .ql-toolbar.ql-snow button:hover .ql-fill,.compose-panel .ql-toolbar.ql-snow button.ql-active .ql-fill{fill:var(--accent-primary)}.compose-panel .ql-toolbar.ql-snow button:hover,.compose-panel .ql-toolbar.ql-snow button.ql-active{background:#6366f11a;border-radius:4px}.compose-panel .ql-snow .ql-tooltip{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.compose-panel .ql-snow .ql-tooltip input[type=text]{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm)}.compose-panel .ql-snow a{color:var(--accent-primary)}.trends-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-1)}.trends-tab{flex:1;padding:var(--space-3) var(--space-4);border:none;background:transparent;color:var(--text-secondary);font-family:var(--font-family);font-size:var(--font-base);font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.trends-tab:hover{color:var(--text-primary);background:var(--bg-glass)}.trends-tab.active{color:var(--text-primary);background:var(--accent-gradient);box-shadow:var(--shadow-sm)}.merch-stats-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.merch-stat-card{flex:1;min-width:100px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center;cursor:pointer;transition:all var(--transition-base)}.merch-stat-card:hover{border-color:var(--border-color-hover);transform:translateY(-2px)}.merch-stat-card.active{border-color:var(--accent-primary);box-shadow:0 0 16px var(--accent-glow)}.merch-stat-label{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-1)}.merch-stat-value{font-size:var(--font-2xl);font-weight:700}.merch-scan-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);padding:var(--space-3) var(--space-5);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md)}.merch-scan-info{font-size:var(--font-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-3)}.merch-scan-status{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600}.merch-scan-status.completed{background:var(--success-bg);color:var(--success)}.merch-scan-status.running{background:#3b82f61a;color:var(--info)}.merch-scan-status.error{background:var(--danger-bg);color:var(--danger)}.scan-stat-group{display:flex;align-items:center;gap:var(--space-2)}.scan-stat{font-size:var(--font-xs);color:var(--text-secondary)}.scan-stat.success{color:var(--success)}.scan-stat.error{color:var(--danger)}.scan-divider{color:var(--border-color);font-size:var(--font-xs);margin:0 var(--space-1)}.merch-category-chips{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4)}.merch-filter-row{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:flex-end}.merch-filter-item{display:flex;flex-direction:column;gap:4px;min-width:120px}.merch-filter-item:first-child{flex:1;min-width:160px}.merch-filter-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.merch-filter-row .form-input,.merch-filter-row .form-select{width:100%;min-width:auto;font-size:var(--font-sm);padding:6px 10px;height:34px}.merch-score-slider{display:flex;align-items:center;gap:8px;height:34px}.merch-range{width:100px;accent-color:var(--accent-primary);cursor:pointer}.merch-score-val{font-size:var(--font-sm);font-weight:700;color:var(--accent-primary-hover);min-width:24px;text-align:center}.merch-filter-check{display:flex;align-items:center;gap:6px;font-size:var(--font-sm);color:var(--text-secondary);cursor:pointer;white-space:nowrap;padding-bottom:6px}.merch-filter-check input{accent-color:var(--accent-primary);cursor:pointer}.merch-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);flex-wrap:wrap;gap:var(--space-2)}.merch-view-tabs{display:flex;gap:2px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:2px}.merch-view-tab{padding:5px 14px;border:none;background:transparent;color:var(--text-muted);font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap}.merch-view-tab:hover{color:var(--text-primary);background:var(--bg-glass)}.merch-view-tab.active{color:#fff;background:var(--accent-primary)}.view-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);font-size:10px;font-weight:700;background:#fff3;margin-left:4px}.merch-view-tab.active .view-tab-badge{background:#ffffff40}.tf-badges{display:flex;gap:3px;flex-wrap:nowrap}.tf-badge{display:inline-flex;align-items:center;justify-content:center;min-width:26px;padding:2px 5px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;letter-spacing:.2px;border:1.5px solid transparent;transition:all var(--transition-fast)}.tf-badge.active{background:#06b6d41f;border-color:#06b6d480;color:#06b6d4}.tf-badge.inactive{background:transparent;border:1.5px dashed rgba(107,114,128,.2);color:var(--text-muted);opacity:.4}.tf-badge.stale{background:#06b6d40d;border:1.5px dashed rgba(6,182,212,.25);color:#06b6d480}.brk-yes{display:inline-flex;padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:700;background:#22c55e26;color:#22c55e}.brk-no{display:inline-flex;padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:700;background:#6b72801a;color:var(--text-muted)}.seeds-val,.evts-val{font-size:var(--font-xs);font-weight:600;color:var(--text-secondary)}.pod-inline{display:inline-flex;padding:1px 5px;border-radius:var(--radius-sm);font-size:9px;font-weight:800;margin-left:4px;vertical-align:middle}.pod-inline.pod-A{background:#22c55e33;color:#22c55e}.pod-inline.pod-B{background:#3b82f633;color:#3b82f6}.pod-inline.pod-C{background:#eab30833;color:#eab308}.pod-inline.pod-D{background:#f9731633;color:#f97316}.pod-inline.pod-F{background:#ef444433;color:#ef4444}.merch-showing-count{font-size:var(--font-xs);color:var(--text-muted)}.merch-table-wrapper{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.merch-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.merch-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:color var(--transition-fast)}.merch-table th:hover{color:var(--text-primary)}.merch-table th.sorted{color:var(--accent-primary-hover)}.merch-table th .sort-arrow{font-size:10px;margin-left:4px}.merch-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.merch-table tr:hover td{background:var(--bg-glass)}.merch-table tr:last-child td{border-bottom:none}.trend-name-cell{display:flex;flex-direction:column;gap:2px}.trend-keyword{font-weight:600;color:var(--text-primary);font-size:var(--font-base);display:inline-flex;align-items:center;gap:4px}.trend-subtitle{font-size:var(--font-xs);color:var(--text-muted)}.btn-copy-kw{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;opacity:0;transition:all var(--transition-fast);flex-shrink:0}.trend-row-clickable:hover .btn-copy-kw{opacity:.6}.btn-copy-kw:hover{opacity:1!important;background:#6366f11f;color:var(--accent-primary)}.btn-copy-kw.copied{opacity:1!important;background:#22c55e26;color:#22c55e;font-size:11px;font-weight:700}.score-bar-wrapper{display:flex;align-items:center;gap:var(--space-2);min-width:120px}.score-bar-bg{flex:1;height:8px;background:#ffffff0f;border-radius:4px;overflow:hidden}.score-bar-fill{height:100%;border-radius:4px;transition:width var(--transition-base)}.score-bar-value{font-size:var(--font-xs);font-weight:700;min-width:28px;text-align:right}.heat-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.heat-badge.EXPLODING{background:#ef444426;color:#ef4444}.heat-badge.HOT{background:#f9731626;color:#f97316}.heat-badge.WARM{background:#eab30826;color:#eab308}.heat-badge.EMERGING{background:#22c55e26;color:#22c55e}.heat-badge.STABLE{background:#6b728026;color:#6b7280}.type-badge{display:inline-flex;padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:700;text-transform:uppercase}.type-badge.BRAND{background:#3b82f626;color:#3b82f6}.type-badge.VIRAL{background:#a855f726;color:#a855f7}.pod-badge{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-sm);font-size:12px;font-weight:800}.pod-badge.pod-A{background:#22c55e33;color:#22c55e}.pod-badge.pod-B{background:#3b82f633;color:#3b82f6}.pod-badge.pod-C{background:#eab30833;color:#eab308}.pod-badge.pod-D{background:#f9731633;color:#f97316}.pod-badge.pod-F{background:#ef444433;color:#ef4444}.breakout-badge{display:inline-flex;padding:2px 6px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;background:#ef444433;color:#ef4444}.sparkline-canvas{display:block}.chain-badge{font-size:var(--font-xs);font-weight:600;color:var(--success)}.chain-badge.zero{color:var(--text-muted)}.time-cell{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap}.merch-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4);border-top:1px solid var(--border-color)}.trend-row-clickable{cursor:pointer}.trend-detail-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-8);overflow-y:auto}.td-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1}.td-content{position:relative;z-index:2;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:900px;box-shadow:var(--shadow-lg);animation:slideUp .25s cubic-bezier(.16,1,.3,1);margin-top:40px}.td-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-12);color:var(--text-secondary)}.td-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-color);gap:var(--space-4)}.td-keyword{font-size:var(--font-xl);font-weight:700;color:var(--accent-primary);margin-bottom:var(--space-2)}.td-badges{display:flex;gap:var(--space-2);flex-wrap:wrap}.td-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.td-badge-EXPLODING{background:#ef4444;color:#fff}.td-badge-HOT{background:#f97316;color:#fff}.td-badge-WARM{background:#eab308;color:#1f2937}.td-badge-EMERGING{background:#22c55e;color:#fff}.td-badge-STABLE{background:#6b7280;color:#fff}.td-badge-type{background:#3b82f626;color:var(--info)}.td-badge-brk{background:#ef4444;color:#fff}.td-badge-pod{background:#8b5cf626;color:#a78bfa}.td-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.td-close{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.td-close:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.td-body{padding:var(--space-6)}.td-ai-box{background:#6366f10f;border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-6);font-size:var(--font-sm);color:var(--text-secondary)}.td-stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-3);margin-bottom:var(--space-4)}.td-stat-card{text-align:center;padding:var(--space-4) var(--space-2);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-color)}.td-stat-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:var(--space-2)}.td-stat-value{font-size:var(--font-2xl);font-weight:800}.td-meta{font-size:var(--font-xs);color:var(--text-muted);padding:var(--space-2) 0;margin-bottom:var(--space-5);border-bottom:1px solid var(--border-color)}.td-tf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:var(--space-3);margin-bottom:var(--space-6)}.td-tf-card{border:1px solid rgba(6,182,212,.25);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);background:#06b6d408}.td-tf-title{font-size:var(--font-md);font-weight:700;color:#06b6d4;margin-bottom:var(--space-2)}.td-tf-row{display:flex;justify-content:space-between;font-size:var(--font-xs);padding:2px 0;color:var(--text-secondary)}.td-tf-row span:last-child{font-weight:600;color:var(--text-primary)}.td-seeds-section{margin-bottom:var(--space-6)}.td-seeds-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:var(--space-3)}.td-seeds-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.td-seed-chip{padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-xs);border:1px solid var(--border-color);color:var(--text-secondary);background:var(--bg-glass)}.td-seed-chip.match{border-color:#06b6d480;background:#06b6d41a;color:#06b6d4;font-weight:600}.td-history-section{margin-bottom:var(--space-4)}.td-history-list{display:flex;flex-direction:column;gap:var(--space-1)}.td-history-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.td-history-row:hover{background:var(--bg-glass)}@media (max-width: 768px){.td-stats-grid{grid-template-columns:repeat(3,1fr)}.td-tf-grid{grid-template-columns:repeat(2,1fr)}.td-content{margin-top:10px}.trend-detail-modal{padding:var(--space-3)}}.td-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color);padding:0 var(--space-6)}.td-tab{padding:var(--space-3) var(--space-5);background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.td-tab:hover{color:var(--text-primary)}.td-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.td-tab-content{padding:var(--space-6)}.td-research-controls{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap}.td-ai-selector{display:flex;gap:var(--space-2)}.td-ai-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.td-ai-btn:hover{border-color:var(--text-muted)}.td-ai-btn.active[data-provider=gemini]{border-color:#4285f4;background:#4285f41a;color:#4285f4}.td-ai-btn.active[data-provider=chatgpt]{border-color:#10a37f;background:#10a37f1a;color:#10a37f}.td-ai-btn.active[data-provider=perplexity]{border-color:#1fb8cd;background:#1fb8cd1a;color:#1fb8cd}.td-ai-btn.active[data-provider=grok]{border-color:#f97316;background:#f973161a;color:#f97316}.td-model-picker{margin-bottom:var(--space-4)}.model-picker-cards{display:flex;gap:var(--space-3);flex-wrap:wrap}.model-card{flex:1;min-width:140px;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-glass);cursor:pointer;transition:all var(--transition-fast);position:relative}.model-card input[type=radio]{position:absolute;opacity:0;pointer-events:none}.model-card:hover{border-color:var(--text-muted);background:#ffffff0a}.model-card.active{border-color:var(--accent-primary);background:#6366f114;box-shadow:0 0 12px #6366f126}.model-card-name{font-size:var(--font-sm);font-weight:700;color:var(--text-primary);margin-bottom:2px}.model-card-desc{font-size:var(--font-xs);color:var(--text-secondary);margin-bottom:4px}.model-card-price{font-size:10px;font-weight:600;color:var(--accent-primary);opacity:.8}.td-research-empty{text-align:center;padding:var(--space-8);color:var(--text-muted);font-size:var(--font-sm)}.td-research-card{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-4);overflow:hidden}.td-research-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);background:#00000005}.td-research-provider{font-weight:700;font-size:var(--font-sm)}.td-research-time{font-size:var(--font-xs);color:var(--text-muted)}.td-research-body{padding:var(--space-4);font-size:var(--font-sm);line-height:1.7;color:var(--text-secondary)}.td-research-body strong{color:var(--text-primary)}.td-research-body h2,.td-research-body h3,.td-research-body h4{color:var(--text-primary);margin:var(--space-3) 0 var(--space-1);font-size:var(--font-md)}.td-research-body li{margin-left:var(--space-4);margin-bottom:var(--space-1)}.trends-filters{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;align-items:center}.trends-filters .form-select,.trends-filters .form-input{width:auto;min-width:140px}.trends-search-bar{flex:1;min-width:200px;position:relative}.trends-search-bar .form-input{padding-left:36px}.trends-search-bar .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:14px;pointer-events:none}.trends-daily-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.trend-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base);cursor:pointer}.trend-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px #6366f11a}.trend-card-header{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3)}.trend-card-image{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.trend-card-title{font-size:var(--font-md);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.trend-card-traffic{font-size:var(--font-xs);color:var(--success);font-weight:600;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--success-bg);border-radius:var(--radius-full)}.trend-card-articles{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}.trend-article-link{font-size:var(--font-xs);color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--bg-glass);border-radius:var(--radius-sm)}.trend-article-link:hover{color:var(--accent-primary-hover)}.trend-article-source{font-size:10px;color:var(--text-muted);margin-left:auto;flex-shrink:0}.trend-related-chips{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-3)}.trend-chart-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.trend-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.trend-chart-title{font-size:var(--font-lg);font-weight:600}.trend-chart-meta{font-size:var(--font-sm);color:var(--text-secondary)}.trend-chart-canvas-wrapper{position:relative;height:280px}.trend-chart-canvas-wrapper canvas{width:100%!important;height:100%!important}.trend-start-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-full);font-size:var(--font-xs);color:var(--warning);margin-top:var(--space-3)}.related-queries-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-6)}.related-queries-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.related-queries-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color);font-weight:600;font-size:var(--font-base);display:flex;align-items:center;gap:var(--space-2)}.related-query-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-5);border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--transition-fast);cursor:pointer}.related-query-item:hover{background:var(--bg-glass)}.related-query-item:last-child{border-bottom:none}.related-query-name{font-size:var(--font-sm);color:var(--text-primary)}.related-query-value{font-size:var(--font-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-full)}.related-query-value.rising{color:var(--success);background:var(--success-bg)}.related-query-value.top{color:var(--info);background:#3b82f61a}.reddit-posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.reddit-post-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);text-decoration:none;color:inherit;display:flex;flex-direction:column}.reddit-post-card:hover{border-color:#ff4500;transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px #ff45001a}.reddit-post-image{width:100%;height:200px;object-fit:cover;background:var(--bg-glass)}.reddit-post-body{padding:var(--space-4);flex:1;display:flex;flex-direction:column}.reddit-post-title{font-size:var(--font-base);font-weight:600;color:var(--text-primary);line-height:1.4;margin-bottom:var(--space-2);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.reddit-post-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-xs);color:var(--text-muted);margin-top:auto;padding-top:var(--space-3)}.reddit-post-score{display:inline-flex;align-items:center;gap:4px;color:#ff4500;font-weight:600}.reddit-post-subreddit{color:var(--text-accent);font-weight:500}.pinterest-trends-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3)}.pinterest-trend-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;transition:all var(--transition-base);cursor:pointer}.pinterest-trend-card:hover{border-color:#e60023;transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px #e600231a}.pinterest-trend-keyword{font-size:var(--font-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.pinterest-trend-growth{font-size:var(--font-sm);color:var(--success);font-weight:600}.pinterest-trend-category{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-2);text-transform:capitalize}.pinterest-trend-image{width:100%;height:120px;border-radius:var(--radius-sm);object-fit:cover;margin-bottom:var(--space-3)}.preset-keywords{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4)}.preset-keyword-btn{padding:var(--space-1) var(--space-3);background:#ff45001a;border:1px solid rgba(255,69,0,.2);border-radius:var(--radius-full);color:#ff6b35;font-size:var(--font-xs);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.preset-keyword-btn:hover{background:#ff450033;border-color:#ff450066}.subreddit-chips{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4)}.subreddit-chip{padding:var(--space-1) var(--space-3);background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-full);color:var(--text-accent);font-size:var(--font-xs);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.subreddit-chip:hover,.subreddit-chip.active{background:#6366f133;border-color:var(--accent-primary);color:var(--text-primary)}.trends-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);color:var(--text-muted);gap:var(--space-4)}.trends-loading .spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.trends-empty{text-align:center;padding:var(--space-12);color:var(--text-muted)}.trends-empty-icon{font-size:48px;margin-bottom:var(--space-4);opacity:.4}.trends-error{padding:var(--space-4) var(--space-6);background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--danger);font-size:var(--font-sm)}@media (max-width: 768px){.trends-tabs{flex-direction:column}.merch-stats-bar{flex-wrap:wrap}.merch-stat-card{min-width:80px;flex:1 1 calc(33% - var(--space-3))}.merch-stat-value{font-size:var(--font-lg)}.merch-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.merch-table{min-width:800px}.trends-daily-grid,.reddit-posts-grid,.related-queries-grid{grid-template-columns:1fr}.merch-filter-row{flex-direction:column;align-items:stretch}.merch-filter-row .form-select,.merch-filter-row .form-input,.merch-range{width:100%}.merch-header-row{flex-direction:column;align-items:flex-start}.merch-scan-bar{flex-direction:column;gap:var(--space-3);align-items:flex-start}.merch-scan-info{flex-wrap:wrap}.pinterest-trends-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.research-banner-body{grid-template-columns:1fr}.tl-heatmap-table{font-size:9px}.tl-cell{padding:var(--space-1) var(--space-2)}}@media (max-width: 480px){.merch-stat-card{flex:1 1 calc(50% - var(--space-2));min-width:0;padding:var(--space-3)}.merch-stat-value{font-size:var(--font-md)}.merch-stat-label{font-size:9px}.trends-tab{font-size:var(--font-sm);padding:var(--space-2) var(--space-3)}.td-stats-grid{grid-template-columns:repeat(2,1fr)}.td-content{margin-top:10px}.trend-detail-modal{padding:var(--space-2)}.td-header{padding:var(--space-4);flex-direction:column}.td-keyword{font-size:var(--font-lg)}.td-body{padding:var(--space-4)}.td-tabs{padding:0 var(--space-3)}.td-tab{padding:var(--space-2) var(--space-3);font-size:var(--font-xs)}.td-tab-content{padding:var(--space-4)}.td-tf-grid{grid-template-columns:1fr}.trend-chart-container{padding:var(--space-4)}.trend-chart-canvas-wrapper{height:200px}.pinterest-trends-grid{grid-template-columns:1fr}}.merch-alert-banner{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);margin-bottom:var(--space-4);background:linear-gradient(135deg,#ef44441f,#f973161f);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);animation:alertPulse 2s ease-in-out infinite}@keyframes alertPulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 16px 2px #ef444426}}.merch-alert-content{display:flex;align-items:center;gap:var(--space-3);flex:1}.merch-alert-icon{font-size:24px}.merch-alert-text{display:flex;flex-direction:column;gap:4px;font-size:var(--font-sm);color:var(--text-primary)}.merch-alert-text>span{display:flex;flex-wrap:wrap;gap:6px}.merch-alert-tag{display:inline-flex;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600}.merch-alert-tag.EXPLODING{background:#ef444433;color:#ef4444}.merch-alert-tag.HOT{background:#f9731633;color:#f97316}.merch-alert-tag-v2{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;border:1.5px solid;cursor:pointer;transition:all var(--transition-fast);position:relative}.merch-alert-tag-v2:hover{filter:brightness(1.15);transform:translateY(-1px)}.alert-dismiss-x{display:none;font-size:10px;font-weight:700;margin-left:2px;opacity:.6;cursor:pointer}.alert-dismiss-x:hover{opacity:1}.merch-alert-tag-v2:hover .alert-dismiss-x{display:inline}.merch-alert-dismiss{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.merch-alert-dismiss:hover{color:var(--text-primary);background:#ffffff1a}.btn-suggest{background:none;border:1px solid rgba(234,179,8,.3);color:#eab308;font-size:14px;cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);transition:all var(--transition-fast);line-height:1}.btn-suggest:hover{background:#eab30826;border-color:#eab308;transform:scale(1.1)}.design-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center}.design-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.design-modal-content{position:relative;width:90%;max-width:640px;max-height:80vh;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 60px #00000080;display:flex;flex-direction:column;overflow:hidden}.design-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.design-modal-header h3{margin:0;font-size:var(--font-lg);color:var(--text-primary)}.design-modal-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.design-modal-close:hover{color:var(--text-primary);background:#ffffff1a}.design-modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.design-suggestions{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.7}.design-suggestions strong{color:var(--text-primary)}.tl-range-btn{padding:5px 14px;border:1.5px solid var(--border-color);background:var(--bg-glass);color:var(--text-muted);font-family:var(--font-family);font-size:var(--font-xs);font-weight:700;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.tl-range-btn:hover{border-color:var(--text-muted);color:var(--text-primary)}.tl-range-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.tl-heatmap-table{width:100%;border-collapse:collapse;font-size:var(--font-xs);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.tl-heatmap-table th{padding:var(--space-2) var(--space-3);text-align:center;font-weight:700;color:var(--text-muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.tl-tf-label{padding:var(--space-2) var(--space-3)!important;font-weight:700;color:#06b6d4;text-align:center;white-space:nowrap;border-right:1px solid var(--border-color)}.tl-cell{padding:var(--space-2) var(--space-3);text-align:center;font-weight:700;font-size:11px;border:1px solid rgba(255,255,255,.03);transition:all var(--transition-fast);white-space:nowrap}.tl-cell:hover{filter:brightness(1.2)}.tl-cell.tl-empty{color:var(--text-muted);opacity:.3;font-weight:400}.tl-count{font-size:9px;font-weight:600;opacity:.6;margin-left:2px}.research-banner{background:var(--bg-card);border:1px solid rgba(139,92,246,.2);border-radius:var(--radius-lg);margin-bottom:var(--space-4);overflow:hidden}.research-banner-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,#8b5cf614,#a855f70a);cursor:pointer;transition:background var(--transition-fast);font-size:var(--font-sm)}.research-banner-header:hover{background:linear-gradient(135deg,#8b5cf624,#a855f714)}.research-banner-arrow{color:var(--text-muted);font-size:11px;transition:transform var(--transition-fast)}.research-banner-body{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-2);padding:var(--space-3)}.research-card{padding:var(--space-3);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.research-card:hover{border-color:#8b5cf666;background:#8b5cf60a;transform:translateY(-1px)}.research-card-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);font-size:var(--font-sm)}.research-card-snippet{font-size:11px;color:var(--text-muted);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
