.admin-layout{display:flex;min-height:calc(100vh - 68px)}.admin-sidebar{width:240px;background:linear-gradient(180deg,#0f172a,#1a1f3a);border-right:1px solid var(--border);padding:var(--spacing-lg) 0;position:sticky;top:68px;height:calc(100vh - 68px);overflow-y:auto;flex-shrink:0;z-index:10}.admin-sidebar-title{padding:0 var(--spacing-lg);margin-bottom:var(--spacing-lg);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.admin-nav{display:flex;flex-direction:column;gap:2px;padding:0 var(--spacing-sm)}.admin-nav-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:all var(--transition-fast);text-decoration:none}.admin-nav-link:hover{color:var(--text-primary);background:#ffffff0d}.admin-nav-link.active{color:var(--text-primary);background:linear-gradient(135deg,#2563eb33,#7c3aed26);border:1px solid rgba(37,99,235,.25)}.admin-nav-icon{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}.admin-nav-badge{margin-left:auto;background:var(--error);color:#fff;font-size:.7rem;font-weight:700;padding:1px 6px;border-radius:10px;min-width:20px;text-align:center}.admin-sidebar-footer{margin-top:auto;padding:var(--spacing-lg) var(--spacing-md);border-top:1px solid var(--border)}.admin-back-link{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:.85rem;text-decoration:none;transition:color var(--transition-fast)}.admin-back-link:hover{color:var(--primary)}.admin-main{flex:1;padding:var(--spacing-xl) var(--spacing-xl);min-width:0;max-width:1200px}.admin-breadcrumb{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.8rem;color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.admin-breadcrumb a{color:var(--text-secondary);text-decoration:none}.admin-breadcrumb a:hover{color:var(--primary)}.admin-breadcrumb-sep{opacity:.4}.admin-breadcrumb-current{color:var(--text-primary);font-weight:500}.admin-page-header{margin-bottom:var(--spacing-xl)}.admin-page-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-sm)}.admin-page-desc{color:var(--text-secondary);font-size:.9rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xs);transition:all var(--transition-fast);position:relative;overflow:hidden}.admin-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);opacity:0;transition:opacity var(--transition-fast)}.admin-stat-card:hover:before{opacity:1}.admin-stat-card:hover{border-color:#2563eb4d;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.admin-stat-card.success:before{background:var(--success)}.admin-stat-card.warning:before{background:var(--warning)}.admin-stat-card.error:before{background:var(--error)}.admin-stat-card.info:before{background:var(--primary)}.admin-stat-icon{font-size:1.5rem;margin-bottom:var(--spacing-xs)}.admin-stat-value{font-size:2rem;font-weight:700;line-height:1}.admin-stat-card.success .admin-stat-value{color:var(--success)}.admin-stat-card.warning .admin-stat-value{color:var(--warning)}.admin-stat-card.error .admin-stat-value{color:var(--error)}.admin-stat-card.info .admin-stat-value{color:var(--primary)}.admin-stat-label{font-size:.85rem;color:var(--text-secondary)}.admin-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.admin-section-title{font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.admin-form-group{margin-bottom:var(--spacing-md)}.admin-form-label{display:block;margin-bottom:var(--spacing-xs);color:var(--text-secondary);font-size:.85rem;font-weight:500}.admin-form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;transition:border-color var(--transition-fast)}.admin-form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb26}.admin-form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem}.admin-form-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.9rem}.admin-form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.admin-form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.admin-section-desc{color:var(--text-secondary);font-size:.85rem;margin:0 0 var(--spacing-md)}.ai-config-category{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:#ffffff05;border:1px solid var(--border);border-radius:var(--radius-lg)}.ai-config-subtitle{color:var(--text-primary);font-size:.95rem;font-weight:600;margin:0 0 var(--spacing-md)}.ai-slider-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.ai-slider-group{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-dark);border-radius:var(--radius-md);border:1px solid transparent;transition:border-color var(--transition-fast)}.ai-slider-group:hover{border-color:var(--primary)}.ai-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.ai-slider-header .admin-form-label{margin-bottom:0}.ai-slider-value{font-size:.85rem;font-weight:700;color:var(--primary);background:#2563eb1f;padding:2px 10px;border-radius:var(--radius-sm);min-width:36px;text-align:center}.ai-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:linear-gradient(90deg,var(--primary) 0%,var(--bg-card) 100%);outline:none;cursor:pointer}.ai-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary);border:2px solid var(--bg-dark);box-shadow:0 0 6px #2563eb66;cursor:pointer;transition:transform .15s ease}.ai-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.ai-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary);border:2px solid var(--bg-dark);box-shadow:0 0 6px #2563eb66;cursor:pointer}.ai-toggle-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.ai-toggle-label{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-dark);border-radius:var(--radius-md);cursor:pointer;border:1px solid transparent;transition:border-color var(--transition-fast)}.ai-toggle-label:hover{border-color:var(--primary)}.ai-toggle-switch{position:relative;flex-shrink:0}.ai-toggle-switch input{opacity:0;width:0;height:0;position:absolute}.ai-toggle-track{display:block;width:44px;height:24px;background:var(--border);border-radius:12px;position:relative;transition:background .25s ease}.ai-toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .25s ease}.ai-toggle-switch input:checked+.ai-toggle-track{background:var(--primary)}.ai-toggle-switch input:checked+.ai-toggle-track:after{transform:translate(20px)}.ai-toggle-text{display:block;font-size:.9rem;font-weight:500;color:var(--text-primary)}.ai-toggle-desc{display:block;font-size:.78rem;color:var(--text-secondary);margin-top:2px}.admin-btn-group{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.admin-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.admin-btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.admin-btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.admin-btn-secondary{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.admin-btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:var(--primary)}.admin-btn-danger{background:#ef444426;border-color:#ef44444d;color:#fca5a5}.admin-btn-danger:hover:not(:disabled){background:#ef444440}.admin-btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8rem}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}.admin-action-card{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;color:inherit;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.admin-action-card:hover{border-color:var(--primary);background:#2563eb0d;transform:translateY(-2px)}.admin-action-icon{font-size:2rem}.admin-action-label{font-weight:600;font-size:.95rem}.admin-action-desc{color:var(--text-secondary);font-size:.8rem}.admin-toast{position:fixed;top:80px;right:24px;z-index:1000;animation:toastIn .3s ease-out;max-width:400px}.admin-toast-content{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);font-size:.9rem;font-weight:500;box-shadow:0 8px 32px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.admin-toast-content.success{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#4ade80}.admin-toast-content.error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.admin-toast-content.info{background:#2563eb26;border:1px solid rgba(37,99,235,.3);color:#93c5fd}.admin-toast-close{background:none;border:none;color:inherit;font-size:1.1rem;cursor:pointer;padding:0;margin-left:var(--spacing-sm);opacity:.7}.admin-toast-close:hover{opacity:1}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.admin-ring-chart{width:120px;height:120px;position:relative;margin:0 auto var(--spacing-md)}.admin-ring-chart svg{transform:rotate(-90deg)}.admin-ring-bg{fill:none;stroke:var(--border);stroke-width:8}.admin-ring-fill{fill:none;stroke:var(--success);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s ease}.admin-ring-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.admin-ring-label{font-size:.7rem;color:var(--text-secondary);font-weight:400}.admin-sync-card{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.admin-sync-info h4{font-size:.95rem;margin-bottom:var(--spacing-xs)}.admin-sync-meta{font-size:.8rem;color:var(--text-secondary)}.admin-sync-meta span{display:block}.admin-empty{text-align:center;padding:var(--spacing-xl) * 2;color:var(--text-secondary)}.admin-empty-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.5}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) * 2;gap:var(--spacing-md);color:var(--text-secondary)}.admin-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.admin-color-input{display:flex;align-items:center;gap:var(--spacing-sm)}.admin-color-input input[type=color]{width:44px;height:38px;border:none;border-radius:var(--radius-sm);cursor:pointer;padding:0}.admin-image-upload{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.admin-image-preview{color:var(--text-secondary);font-size:.8rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-photo-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border);padding-bottom:var(--spacing-sm)}.admin-photo-tab{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md) var(--radius-md) 0 0;background:transparent;color:var(--text-secondary);font-weight:500;font-size:.85rem;border:none;cursor:pointer;transition:all var(--transition-fast)}.admin-photo-tab:hover{color:var(--text-primary);background:#ffffff0d}.admin-photo-tab.active{color:var(--primary);background:#2563eb1a;border-bottom:2px solid var(--primary)}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:static;padding:var(--spacing-md) 0;border-right:none;border-bottom:1px solid var(--border)}.admin-nav{flex-direction:row;overflow-x:auto;padding:0 var(--spacing-md);gap:var(--spacing-xs);-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-snap-type:x mandatory}.admin-nav::-webkit-scrollbar{display:none}.admin-nav-link{white-space:nowrap;font-size:.8rem;padding:var(--spacing-xs) var(--spacing-sm);scroll-snap-align:start;flex-shrink:0}.admin-sidebar-title,.admin-sidebar-footer{display:none}.admin-main{padding:var(--spacing-md)}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}.brand-nav{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.08)}.brand-nav-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.brand-nav-refresh{background:none;border:none;cursor:pointer;font-size:.85rem;padding:2px 6px;border-radius:4px;transition:background .2s}.brand-nav-refresh:hover{background:#ffffff14}.brand-nav-refresh:disabled{opacity:.4;cursor:default}.brand-nav-loading{padding:var(--spacing-md);color:var(--text-secondary);font-size:.85rem;text-align:center}.brand-nav-list{max-height:calc(100vh - 400px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.brand-nav-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px var(--spacing-md);background:none;border:none;color:var(--text-primary);font-size:.88rem;cursor:pointer;text-align:left;transition:background .15s;border-radius:0}.brand-nav-btn:hover{background:#ffffff0f}.brand-nav-btn.expanded{background:#2563eb1f}.brand-arrow{font-size:.6rem;transition:transform .25s ease;color:var(--text-secondary);flex-shrink:0}.brand-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand-badge{font-size:.72rem;padding:1px 7px;border-radius:10px;background:#2563eb40;color:#93bbfc;font-weight:600;flex-shrink:0}.brand-badge.empty{background:#ef444440;color:#fca5a5}.model-nav-list{animation:slideDown .2s ease}.model-nav-btn{display:flex;align-items:center;justify-content:space-between;gap:6px;width:100%;padding:6px var(--spacing-md) 6px 38px;background:none;border:none;color:var(--text-secondary);font-size:.82rem;cursor:pointer;text-align:left;transition:all .15s}.model-nav-btn:hover{background:#ffffff0d;color:var(--text-primary)}.model-nav-btn.active{background:#2563eb33;color:#93bbfc;border-right:2px solid var(--primary)}.model-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.model-badge{font-size:.68rem;padding:0 5px;border-radius:8px;background:#ffffff14;color:var(--text-secondary);flex-shrink:0}.model-badge.empty{background:#ef444433;color:#fca5a5}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.photo-mgmt{padding:var(--spacing-md) 0}.photo-mgmt-header{margin-bottom:var(--spacing-lg)}.photo-mgmt-title{display:flex;align-items:center;gap:var(--spacing-md)}.photo-mgmt-title h2{margin:0;font-size:1.4rem;font-weight:700;color:var(--text-primary)}.photo-count-badge{font-size:.82rem;padding:4px 12px;border-radius:16px;background:linear-gradient(135deg,#2563eb33,#7c3aed33);color:#93bbfc;font-weight:600;border:1px solid rgba(37,99,235,.2)}.photo-dropzone{border:2px dashed rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-xl) var(--spacing-lg);text-align:center;cursor:pointer;transition:all .25s ease;background:#ffffff05;margin-bottom:var(--spacing-md)}.photo-dropzone:hover{border-color:#2563eb80;background:#2563eb0f}.photo-dropzone.drag-over{border-color:var(--primary);background:#2563eb1f;transform:scale(1.01);box-shadow:0 0 30px #2563eb26}.photo-dropzone.uploading{cursor:wait;opacity:.7}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone-icon{font-size:2.2rem;filter:grayscale(.3)}.dropzone-text{font-size:1rem;color:var(--text-primary);font-weight:500}.dropzone-hint{font-size:.8rem;color:var(--text-secondary)}.upload-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.1);border-top:3px solid var(--primary);border-radius:50%;animation:spin .8s linear infinite}.photo-upload-options{margin-bottom:var(--spacing-lg)}.color-input-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.88rem;color:var(--text-secondary)}.color-input{padding:6px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:.85rem;width:240px;transition:border-color .2s}.color-input:focus{outline:none;border-color:var(--primary)}.color-input::placeholder{color:var(--text-secondary);opacity:.6}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}.photo-grid-loading,.photo-grid-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl) * 2;color:var(--text-secondary);font-size:.95rem}.photo-grid-empty span{font-size:2.5rem}.photo-grid-empty p{margin:0}.photo-card{background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);transition:all .25s ease;animation:fadeInUp .3s ease forwards;opacity:0}.photo-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.photo-card-img{position:relative;aspect-ratio:4/3;background:#0003;overflow:hidden}.photo-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-card:hover .photo-card-img img{transform:scale(1.05)}.photo-delete-btn{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;border:none;background:#ef4444d9;color:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.photo-card:hover .photo-delete-btn{opacity:1;transform:scale(1)}.photo-delete-btn:hover{background:var(--error);transform:scale(1.15)!important}.photo-card-info{padding:10px 12px}.photo-filename{display:block;font-size:.78rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}.photo-badges{display:flex;gap:6px;flex-wrap:wrap}.badge{font-size:.68rem;padding:2px 8px;border-radius:10px;font-weight:600;text-transform:capitalize}.badge-color{background:#22c55e33;color:#86efac;border:1px solid rgba(34,197,94,.2)}.badge-source-selected{background:#2563eb33;color:#93bbfc}.badge-source-crawled{background:#7c3aed33;color:#c4b5fd}.badge-source-vs{background:#f59e0b33;color:#fcd34d}.badge-source-ego{background:#ec489933;color:#f9a8d4}.badge-source-default{background:#ffffff14;color:var(--text-secondary)}.photo-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center;animation:fadeInUp .4s ease}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);filter:grayscale(.3)}.photo-empty-state h2{color:var(--text-primary);margin:0 0 var(--spacing-sm);font-size:1.5rem}.photo-empty-state p{color:var(--text-secondary);margin:0 0 var(--spacing-lg);font-size:1rem}.empty-hint{display:flex;align-items:center;gap:var(--spacing-sm);padding:12px 20px;border-radius:var(--radius-md);background:#2563eb14;border:1px solid rgba(37,99,235,.15);color:var(--text-secondary);font-size:.88rem}.photo-toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;z-index:1000;animation:toastIn .3s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 30px #0006}.photo-toast.success{background:#22c55ee6;color:#fff}.photo-toast.error{background:#ef4444e6;color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.photo-mgmt-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.save-order-btn{padding:8px 20px;border:1px solid rgba(34,197,94,.4);border-radius:var(--radius-md);background:linear-gradient(135deg,#22c55e33,#10b98126);color:#86efac;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .25s ease;animation:fadeInUp .3s ease}.save-order-btn:hover:not(:disabled){background:linear-gradient(135deg,#22c55e59,#10b9814d);border-color:#22c55e99;transform:translateY(-1px);box-shadow:0 4px 16px #22c55e33}.save-order-btn:disabled{opacity:.6;cursor:wait}.sort-hint{display:flex;align-items:center;gap:6px;padding:8px 14px;margin-bottom:var(--spacing-md);border-radius:var(--radius-md);background:#7c3aed14;border:1px solid rgba(124,58,237,.15);color:var(--text-secondary);font-size:.82rem}.photo-card[draggable=true]{cursor:grab}.photo-card[draggable=true]:active{cursor:grabbing}.photo-card.dragging{opacity:.35;transform:scale(.95)!important;border-color:var(--primary)!important;box-shadow:0 0 20px #2563eb33}.photo-card.drag-target{border-color:#60a5fa!important;background:#2563eb14;box-shadow:0 0 0 3px #2563eb26;transform:scale(1.02)!important;transition:all .15s ease}.photo-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000059;opacity:0;transition:opacity .2s ease;pointer-events:none}.photo-card:hover .photo-card-overlay{opacity:1}.drag-handle{font-size:1.8rem;color:#fffc;text-shadow:0 2px 4px rgba(0,0,0,.5);letter-spacing:3px}.confirm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:modalOverlayIn .2s ease}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.confirm-modal{background:linear-gradient(160deg,#1e293b,#0f172a);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);width:90%;max-width:420px;box-shadow:0 24px 60px #0009,0 0 0 1px #ffffff0d;overflow:hidden;animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-modal-header{padding:20px 24px 0}.confirm-modal-header h3{margin:0;font-size:1.15rem;font-weight:700;color:var(--text-primary)}.confirm-modal-body{padding:16px 24px 20px;text-align:center}.confirm-modal-preview{width:100%;max-height:200px;border-radius:var(--radius-md);overflow:hidden;margin-bottom:14px;background:#0000004d}.confirm-modal-preview img{width:100%;height:100%;max-height:200px;object-fit:contain}.confirm-modal-filename{font-size:.85rem;color:var(--text-primary);font-weight:600;margin:0 0 8px;word-break:break-all}.confirm-modal-warning{font-size:.82rem;color:#fca5a5;margin:0;padding:10px 14px;border-radius:var(--radius-md);background:#ef44441a;border:1px solid rgba(239,68,68,.15)}.confirm-modal-actions{display:flex;gap:10px;padding:0 24px 20px;justify-content:flex-end}.confirm-modal-cancel{padding:8px 20px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-hover);color:var(--text-primary);font-size:.88rem;font-weight:500;cursor:pointer;transition:all .2s}.confirm-modal-cancel:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.confirm-modal-confirm{padding:8px 20px;border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.4);background:linear-gradient(135deg,#ef4444cc,#dc2626d9);color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s}.confirm-modal-confirm:hover:not(:disabled){background:linear-gradient(135deg,#ef4444f2,#dc2626);transform:translateY(-1px);box-shadow:0 4px 16px #ef44444d}.confirm-modal-confirm:disabled,.confirm-modal-cancel:disabled{opacity:.5;cursor:not-allowed}.db-overview{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.db-source-details{display:flex;gap:var(--spacing-sm);font-size:.75rem;color:var(--text-secondary);margin-top:var(--spacing-xs);flex-wrap:wrap}.db-source-details span:before{content:"•";margin-right:4px;opacity:.5}.db-source-details span:first-child:before{display:none}.db-bar-chart{display:flex;height:24px;border-radius:var(--radius-md);overflow:hidden;margin-top:var(--spacing-md)}.db-bar-segment{transition:width .8s ease;min-width:2px;position:relative}.db-bar-segment:hover{opacity:.85;filter:brightness(1.15)}.db-bar-legend{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm);font-size:.8rem;color:var(--text-secondary)}.db-bar-legend-item{display:flex;align-items:center;gap:6px}.db-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.db-field-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-md)}.db-field-item{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md)}.db-field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.db-field-name{font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.03em}.db-field-rate{font-weight:700;font-size:.9rem}.db-field-rate.good{color:var(--success)}.db-field-rate.warn{color:var(--warning)}.db-field-rate.bad{color:var(--error)}.db-field-bar-bg{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden;margin-bottom:var(--spacing-xs)}.db-field-bar-fill{height:100%;border-radius:3px;transition:width .8s ease}.db-field-bar-fill.good{background:var(--success)}.db-field-bar-fill.warn{background:var(--warning)}.db-field-bar-fill.bad{background:var(--error)}.db-field-count{font-size:.75rem;color:var(--text-secondary);text-align:right}.db-size-chart{display:flex;align-items:flex-end;gap:6px;height:200px;padding:var(--spacing-md) 0}.db-size-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;gap:4px}.db-size-bar{width:100%;min-height:4px;background:linear-gradient(to top,var(--primary),#7c3aed);border-radius:4px 4px 0 0;transition:height .6s ease}.db-size-count{font-size:.7rem;color:var(--text-secondary);font-weight:600}.db-size-label{font-size:.75rem;color:var(--text-secondary)}.db-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.db-table{width:100%;border-collapse:collapse;font-size:.85rem}.db-table th{text-align:left;padding:var(--spacing-sm) var(--spacing-md);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.db-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.04)}.db-table tbody tr:hover{background:#ffffff08}.db-brand-cell{font-weight:600}.db-id-cell{font-family:SF Mono,monospace;color:var(--text-secondary);font-size:.8rem}.db-time-cell{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.db-source-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:.75rem;border:1px solid;background:#ffffff08}.product-visibility{max-width:1100px}.visibility-toolbar{display:flex;gap:var(--spacing-md);align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap}.visibility-search{flex:1;min-width:240px;display:flex;align-items:center;position:relative}.visibility-search .search-icon{position:absolute;left:12px;font-size:1rem;z-index:1;opacity:.6}.visibility-search .admin-form-input{padding-left:36px;width:100%}.visibility-search .search-clear{position:absolute;right:10px;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:4px 6px;border-radius:4px}.visibility-search .search-clear:hover{background:var(--surface-elevated);color:var(--text-primary)}.visibility-brands{display:flex;flex-direction:column;gap:var(--spacing-sm)}.visibility-brand-group{background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s}.visibility-brand-group:hover{border-color:var(--border-default)}.visibility-brand-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.visibility-brand-header:hover{background:var(--surface-hover)}.visibility-brand-info{display:flex;align-items:center;gap:var(--spacing-sm)}.brand-arrow{font-size:.7rem;transition:transform .2s;color:var(--text-secondary)}.brand-arrow.open{transform:rotate(90deg)}.visibility-brand-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.visibility-brand-count{font-size:.8rem;color:var(--text-secondary);background:var(--surface-elevated);padding:2px 8px;border-radius:10px}.visibility-hidden-badge{font-size:.75rem;color:var(--color-warning, #f59e0b);background:#f59e0b1f;padding:2px 8px;border-radius:10px;font-weight:500}.visibility-brand-actions{display:flex;gap:var(--spacing-xs)}.visibility-model-list{border-top:1px solid var(--border-subtle)}.visibility-model-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-lg);padding-left:calc(var(--spacing-lg) + 20px);transition:background .15s,opacity .2s}.visibility-model-row:not(:last-child){border-bottom:1px solid var(--border-subtle)}.visibility-model-row:hover{background:var(--surface-hover)}.visibility-model-row.hidden-product{opacity:.55}.visibility-model-row.hidden-product:hover{opacity:.75}.visibility-model-info{display:flex;align-items:center;gap:var(--spacing-md);min-width:0}.visibility-model-img{width:48px;height:48px;object-fit:contain;border-radius:var(--radius-md);background:var(--surface-elevated);flex-shrink:0}.visibility-model-img-placeholder{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-elevated);border-radius:var(--radius-md);font-size:1.4rem;flex-shrink:0}.visibility-model-details{display:flex;flex-direction:column;gap:2px;min-width:0}.visibility-model-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.visibility-model-meta{font-size:.78rem;color:var(--text-secondary)}.visibility-toggle{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;flex-shrink:0}.visibility-status{font-size:.8rem;font-weight:500;min-width:50px;text-align:right}.visibility-status.on{color:var(--color-success, #22c55e)}.visibility-status.off{color:var(--text-secondary)}.admin-btn-sm{padding:4px 10px;font-size:.78rem}.admin-btn-danger{color:#ef4444;border:1px solid rgba(239,68,68,.3);background:transparent}.admin-btn-danger:hover:not(:disabled){background:#ef44441f}.admin-btn-danger:disabled{opacity:.4;cursor:not-allowed}.admin-stat-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-lg);background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);min-width:140px}.admin-stat-icon{font-size:1.5rem}.admin-stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary);font-family:Inter,SF Mono,monospace}.admin-stat-label{font-size:.8rem;color:var(--text-secondary)}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.admin-stat-card.info{border-color:#3b82f64d}.admin-stat-card.success{border-color:#22c55e4d}.admin-stat-card.warning{border-color:#f59e0b4d}.admin-empty{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);color:var(--text-secondary)}.admin-empty-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm);opacity:.5}@media(max-width:768px){.visibility-brand-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.visibility-brand-actions{margin-left:auto}.visibility-model-row{padding-left:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.visibility-model-info{flex:1}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}.admin-stat-card.primary{border-left-color:#6366f1}.admin-stat-card.primary .admin-stat-icon{color:#6366f1}.pm-brand-photos-badge{font-size:.75rem;color:#6366f1;background:#6366f11a;padding:2px 8px;border-radius:10px;margin-left:4px;white-space:nowrap}.pm-model-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.pm-photo-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;border:1px solid #d1d5db;background:#f9fafb;color:#374151;font-size:.8rem;cursor:pointer;transition:all .2s;white-space:nowrap}.pm-photo-btn:hover{background:#e0e7ff;border-color:#818cf8;color:#4338ca}.pm-photo-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.pm-photo-btn.empty{opacity:.5}.pm-photo-btn-count{font-weight:600;min-width:1ch}.visibility-model-row.photo-active{background:#6366f10f;border-left:3px solid #6366f1}.pm-photo-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:0 0 10px 10px;margin:0 var(--spacing-md) var(--spacing-sm);padding:var(--spacing-md);animation:pmPanelSlide .3s ease}@keyframes pmPanelSlide{0%{opacity:0;max-height:0;transform:translateY(-8px)}to{opacity:1;max-height:2000px;transform:translateY(0)}}.pm-photo-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid #e2e8f0}.pm-photo-panel-header h3{margin:0;font-size:1rem;color:#334155}.pm-photo-panel-actions{display:flex;gap:var(--spacing-xs)}.pm-dropzone{border:2px dashed #cbd5e1;border-radius:10px;padding:var(--spacing-md);text-align:center;cursor:pointer;transition:all .2s;background:#fff;margin-bottom:var(--spacing-sm)}.pm-dropzone:hover{border-color:#818cf8;background:#f5f3ff}.pm-dropzone.drag-over{border-color:#6366f1;background:#eef2ff;transform:scale(1.01)}.pm-dropzone.uploading{opacity:.7;pointer-events:none}.pm-dropzone .dropzone-icon{font-size:1.5rem;margin-bottom:4px}.pm-dropzone .dropzone-text{display:block;font-size:.85rem;color:#475569}.pm-dropzone .dropzone-hint{display:block;font-size:.75rem;color:#94a3b8;margin-top:2px}.pm-upload-options{margin-bottom:var(--spacing-sm)}.pm-sort-hint{display:flex;align-items:center;gap:6px;font-size:.78rem;color:#94a3b8;margin-bottom:var(--spacing-sm)}.pm-photos-loading,.pm-photos-empty{text-align:center;padding:var(--spacing-lg);color:#94a3b8}.pm-photos-loading .upload-spinner{margin:0 auto var(--spacing-sm)}.pm-photos-empty span{font-size:2rem;display:block;margin-bottom:var(--spacing-sm)}.pm-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-sm)}.pm-photo-card{border-radius:8px;overflow:hidden;background:#fff;border:1px solid #e2e8f0;transition:all .2s;cursor:grab;animation:fadeInUp .3s ease both}.pm-photo-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.pm-photo-card:hover .photo-delete-btn{opacity:1;transform:scale(1)}.pm-photo-card:hover .photo-card-overlay{opacity:1}.pm-photo-card.dragging{opacity:.4;transform:scale(.95)}.pm-photo-card.drag-target{border-color:#6366f1;box-shadow:0 0 0 2px #6366f14d}.pm-photo-card-img{position:relative;aspect-ratio:1;overflow:hidden;background:#f1f5f9}.pm-photo-card-img img{width:100%;height:100%;object-fit:cover}.pm-photo-card-info{padding:6px 8px}.pm-photo-card-info .photo-filename{font-size:.7rem;color:#64748b;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pm-photo-card-info .photo-badges{display:flex;gap:4px;margin-top:3px;flex-wrap:wrap}.photo-sort-buttons{display:flex;align-items:center;gap:2px;margin-bottom:4px}.photo-sort-buttons .sort-btn{background:#6366f126;border:1px solid rgba(99,102,241,.3);color:#818cf8;font-size:.65rem;width:22px;height:22px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;padding:0;line-height:1}.photo-sort-buttons .sort-btn:hover:not(:disabled){background:#6366f159;color:#a5b4fc;transform:scale(1.1)}.photo-sort-buttons .sort-btn:disabled{opacity:.25;cursor:not-allowed}.photo-sort-buttons .sort-position{font-size:.65rem;color:#94a3b8;min-width:16px;text-align:center;font-weight:600}@media(max-width:768px){.pm-photo-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.pm-model-actions{flex-wrap:wrap}.pm-photo-panel{margin:0 var(--spacing-xs) var(--spacing-xs);padding:var(--spacing-sm)}}.photo-audit{max-width:1400px;margin:0 auto;padding:24px}.photo-audit h1{font-size:1.6rem;margin-bottom:24px;color:var(--text-primary, #e0e0e0)}.audit-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}.summary-card{background:var(--bg-card, #1e1e2e);border-radius:12px;padding:16px;text-align:center;border:1px solid var(--border-color, #333);transition:transform .2s}.summary-card:hover{transform:translateY(-2px)}.card-number{font-size:2rem;font-weight:700;margin-bottom:4px}.card-label{font-size:.85rem;color:var(--text-secondary, #999)}.summary-card.matched .card-number{color:#4ade80}.summary-card.missing .card-number{color:#f87171}.summary-card.low .card-number{color:#fbbf24}.summary-card.rate .card-number{color:#60a5fa}.summary-card.total .card-number{color:#c084fc}.audit-toolbar{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.filter-group{display:flex;gap:6px}.filter-group button{padding:8px 14px;border:1px solid var(--border-color, #444);border-radius:8px;background:var(--bg-card, #1e1e2e);color:var(--text-secondary, #aaa);cursor:pointer;font-size:.85rem;transition:all .2s}.filter-group button:hover{border-color:var(--accent, #7c3aed);color:var(--text-primary, #e0e0e0)}.filter-group button.active{background:var(--accent, #7c3aed);border-color:var(--accent, #7c3aed);color:#fff}.audit-search{flex:1;min-width:200px;padding:8px 14px;border:1px solid var(--border-color, #444);border-radius:8px;background:var(--bg-card, #1e1e2e);color:var(--text-primary, #e0e0e0);font-size:.9rem}.audit-search:focus{outline:none;border-color:var(--accent, #7c3aed)}.audit-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color, #333)}.audit-table{width:100%;border-collapse:collapse;font-size:.9rem}.audit-table th,.audit-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border-color, #2a2a3a)}.audit-table th{background:var(--bg-card, #1a1a2e);color:var(--text-secondary, #aaa);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0}.audit-table tbody tr{transition:background .15s}.audit-table tbody tr:hover{background:#7c3aed14}.audit-table tr.status-missing{background:#f871710d}.audit-table tr.status-low{background:#fbbf240d}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:500;white-space:nowrap}.status-badge.ok{background:#4ade8026;color:#4ade80}.status-badge.low{background:#fbbf2426;color:#fbbf24}.status-badge.missing{background:#f8717126;color:#f87171}.preview-img{width:60px;height:60px;object-fit:cover;border-radius:8px;border:1px solid var(--border-color, #444);cursor:pointer;transition:transform .2s}.preview-img:hover{transform:scale(2.5);z-index:10;position:relative;box-shadow:0 8px 30px #00000080}.no-photo{color:var(--text-secondary, #666)}.file-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:4px}.file-list li{display:flex;gap:3px;align-items:center}.color-tag{font-size:.75rem;padding:2px 6px;border-radius:4px;background:#60a5fa26;color:#60a5fa}.priority-tag{font-size:.7rem;padding:1px 4px;border-radius:3px;background:#c084fc1f;color:#c084fc}.orphan-section{margin-top:32px}.orphan-section h2{font-size:1.2rem;margin-bottom:16px;color:var(--text-primary, #e0e0e0)}.orphan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.orphan-card{background:var(--bg-card, #1e1e2e);border:1px solid var(--border-color, #333);border-radius:10px;padding:14px}.orphan-key{font-weight:600;color:var(--text-primary, #e0e0e0);margin-bottom:6px}.orphan-count{font-size:.85rem;color:var(--text-secondary, #999);margin-bottom:4px}.orphan-samples{font-size:.75rem;color:var(--text-secondary, #777);word-break:break-all}.audit-loading,.audit-error{text-align:center;padding:60px 20px;font-size:1.1rem;color:var(--text-secondary, #999)}.audit-error{color:#f87171}.upload-link{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;background:#2563eb26;color:#60a5fa;font-size:.8rem;font-weight:500;text-decoration:none;transition:all .2s;white-space:nowrap}.upload-link:hover{background:#2563eb4d;color:#93c5fd}.action-cell{white-space:nowrap}@media(max-width:768px){.photo-audit{padding:12px}.audit-toolbar{flex-direction:column}.filter-group{flex-wrap:wrap}.audit-search{width:100%}.preview-img{width:45px;height:45px}}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--secondary: #7c3aed;--secondary-hover: #6d28d9;--bg-dark: #0f172a;--bg-card: #1e293b;--bg-hover: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--border: #334155;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .25s ease}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-dark);color:var(--text-primary);line-height:1.6;min-height:100vh}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover)}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;outline:none}input,select{font-family:inherit;font-size:inherit}.container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg)}.header{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(37,99,235,.1) 100%);border-bottom:1px solid var(--border);padding:var(--spacing-lg) 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg)}.logo{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{display:flex;gap:var(--spacing-md)}.nav-link{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--text-primary);background:var(--bg-hover)}.hero{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);padding:var(--spacing-xl) 0;text-align:center;position:relative;overflow:hidden}.hero.hero-enhanced{padding:var(--spacing-xl) 0 calc(var(--spacing-xl) + var(--spacing-lg))}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.hero-content{position:relative;z-index:1;max-width:720px;margin:0 auto;padding:0 var(--spacing-lg)}.hero h1{font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-sm);text-shadow:0 2px 4px rgba(0,0,0,.2)}.hero p{font-size:1.125rem;opacity:.9;margin-bottom:var(--spacing-lg)}.hero-vehicle-search{margin-top:var(--spacing-md)}.hero-search-wrapper{display:flex;align-items:center;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-xl);padding:6px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-normal)}.hero-search-wrapper:focus-within{background:#ffffff2e;border-color:#ffffff80;box-shadow:0 0 0 4px #ffffff1a}.hero-search-icon{padding:0 var(--spacing-sm) 0 var(--spacing-md);font-size:1.25rem;flex-shrink:0}.hero-search-input{flex:1;background:none;border:none;color:#fff;font-size:1rem;padding:var(--spacing-sm) var(--spacing-sm);outline:none;min-width:0}.hero-search-input::placeholder{color:#fff9}.hero-search-btn{flex-shrink:0;padding:var(--spacing-sm) var(--spacing-lg);background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-lg);color:#fff;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.hero-search-btn:hover:not(:disabled){background:#ffffff4d;transform:translateY(-1px)}.hero-search-btn:disabled{opacity:.5;cursor:not-allowed}.hero-btn-loading{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.hero-search-hint{margin-top:var(--spacing-sm);font-size:.8125rem;color:#ffffff8c}.ai-progress-panel{margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:#ffffff0f;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeInUp .4s ease}.ai-progress-panel-page{background:var(--bg-card);border:1px solid var(--border);margin-bottom:var(--spacing-lg)}.ai-progress-steps{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.ai-progress-step{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px 0;opacity:.4;transition:all .4s ease;font-size:.9rem}.ai-progress-step.active{opacity:1;color:var(--primary)}.ai-progress-step.active .ai-progress-step-label{color:#fff;font-weight:500}.ai-progress-panel-page .ai-progress-step.active .ai-progress-step-label{color:var(--text-primary)}.ai-progress-step.done{opacity:.7}.ai-progress-step.done .ai-progress-step-label{text-decoration:line-through;color:#ffffff80}.ai-progress-panel-page .ai-progress-step.done .ai-progress-step-label{color:var(--text-secondary)}.ai-progress-step-icon{font-size:1.1rem;min-width:1.5rem;text-align:center}.ai-progress-step.active .ai-progress-step-icon{animation:pulse 1.2s ease-in-out infinite}.ai-progress-step-label{font-size:.875rem;color:#ffffff80;transition:color .3s ease}.ai-progress-bar-wrapper{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin-bottom:var(--spacing-xs)}.ai-progress-panel-page .ai-progress-bar-wrapper{background:#6366f126}.ai-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),#818cf8);border-radius:2px;transition:width .3s ease;position:relative}.ai-progress-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s ease-in-out infinite}.ai-progress-percent{text-align:right;font-size:.75rem;color:#fff9;font-weight:600;font-variant-numeric:tabular-nums}.ai-progress-panel-page .ai-progress-percent{color:var(--primary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.ai-error-banner{display:flex;align-items:center;justify-content:space-between;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-md);color:#fca5a5;font-size:.875rem}.ai-error-close{background:none;border:none;color:#fca5a5;font-size:1rem;padding:var(--spacing-xs);cursor:pointer;opacity:.7;transition:opacity var(--transition-fast)}.ai-error-close:hover{opacity:1}.vehicle-spec-panel{background:linear-gradient(135deg,#7c3aed14,#2563eb14);border-bottom:1px solid rgba(124,58,237,.2);padding:var(--spacing-lg) 0;animation:specPanelIn .4s ease-out}@keyframes specPanelIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.spec-panel-inner{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid rgba(124,58,237,.25);padding:var(--spacing-lg);box-shadow:0 4px 24px #7c3aed1a}.spec-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.spec-panel-title{display:flex;align-items:center;gap:var(--spacing-md)}.spec-panel-icon{font-size:2rem;background:linear-gradient(135deg,var(--primary),var(--secondary));width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.spec-panel-title h3{font-size:1.125rem;font-weight:600;margin:0;color:var(--text-primary)}.spec-panel-subtitle{font-size:.8125rem;color:var(--text-secondary);margin:2px 0 0}.spec-panel-close{background:var(--bg-hover);border:1px solid var(--border);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:all var(--transition-fast)}.spec-panel-close:hover{background:#ef444426;border-color:#ef44444d;color:#fca5a5}.spec-panel-basics{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.spec-basic-item{flex:1;min-width:120px;background:var(--bg-hover);padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center}.spec-basic-item.spec-basic-highlight{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border:1px solid rgba(34,197,94,.2)}.spec-basic-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.spec-basic-value{font-size:1rem;font-weight:600;color:var(--text-primary)}.spec-basic-highlight .spec-basic-value{color:var(--success)}.spec-sizes-section{margin-bottom:var(--spacing-md)}.spec-sizes-label{display:block;font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--spacing-sm);font-weight:500}.spec-sizes-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.spec-size-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);min-width:110px}.spec-size-btn:hover{border-color:var(--primary);background:#2563eb1a;color:var(--text-primary)}.spec-size-btn.active{background:linear-gradient(135deg,var(--primary),var(--secondary));border-color:transparent;color:#fff;box-shadow:0 2px 12px #2563eb4d}.spec-size-diameter{font-size:1.125rem;font-weight:700;line-height:1.2}.spec-size-detail{font-size:.6875rem;opacity:.75}.spec-size-tire{font-size:.6875rem;opacity:.6}.spec-size-btn.active .spec-size-detail,.spec-size-btn.active .spec-size-tire{opacity:.9}.spec-panel-notes{background:#2563eb14;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.8125rem;color:var(--primary);line-height:1.5}.products-ai-badge{color:var(--secondary);font-weight:600}.search-container{padding:var(--spacing-lg) 0;background:var(--bg-card);border-bottom:1px solid var(--border)}.search-bar{display:flex;gap:var(--spacing-md);flex-wrap:wrap;align-items:center}.search-input-wrapper{flex:1;min-width:280px;position:relative}.search-input{width:100%;padding:var(--spacing-md) var(--spacing-lg);padding-left:3rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:1rem;transition:all var(--transition-fast)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb33}.search-input::placeholder{color:var(--text-secondary)}.search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary)}.filter-select{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);min-width:150px;transition:border-color var(--transition-fast)}.filter-select:focus{border-color:var(--primary);outline:none}.products-section{padding:var(--spacing-xl) 0}.brand-quick-bar{display:flex;gap:.5rem;padding:.75rem 0;margin-bottom:var(--spacing-lg);overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--text-muted) transparent;-webkit-overflow-scrolling:touch}.brand-quick-bar::-webkit-scrollbar{height:4px}.brand-quick-bar::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:2px}.brand-quick-pill{flex-shrink:0;padding:.4rem 1rem;border:1px solid var(--border-color);border-radius:999px;background:var(--bg-card);color:var(--text-secondary);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.brand-quick-pill:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:hsla(var(--accent-primary-hsl, 220, 90%, 56%),.08)}.brand-quick-pill.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary, var(--accent-primary)));color:#fff;border-color:transparent;box-shadow:0 2px 8px hsla(var(--accent-primary-hsl, 220, 90%, 56%),.3)}.filter-pills-brand{flex-wrap:wrap}.products-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-xl);align-items:start}.products-main{min-width:0}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.products-count{color:var(--text-secondary);font-size:.875rem}.products-ai-badge{color:var(--primary);font-weight:600}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-lg)}.view-mode-container{background:var(--bg-card);border-bottom:1px solid var(--border);padding:var(--spacing-sm) 0;position:sticky;top:60px;z-index:10}.view-mode-switch{display:flex;gap:var(--spacing-xs)}.view-mode-btn{padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.view-mode-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.filter-mobile-trigger,.filter-overlay{display:none}.filter-sidebar{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);padding:var(--spacing-md);position:sticky;top:112px;max-height:calc(100vh - 130px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--bg-hover) transparent}.filter-sidebar-header{display:none}.filter-sidebar-header h3{font-size:1.1rem;color:var(--text-primary)}.filter-close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer}.filter-search-section{padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border);margin-bottom:var(--spacing-md)}.filter-search-wrapper{display:flex;align-items:center;background:var(--bg-dark);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border);transition:border-color var(--transition-fast)}.filter-search-wrapper:focus-within{border-color:var(--primary)}.filter-search-icon{font-size:.875rem;margin-right:var(--spacing-xs)}.filter-search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.85rem}.filter-search-input::placeholder{color:var(--text-secondary)}.filter-active-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border);margin-bottom:var(--spacing-md)}.filter-tag{display:inline-flex;align-items:center;gap:4px;background:#2563eb26;border:1px solid rgba(37,99,235,.3);color:var(--primary);padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.filter-tag-remove{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.875rem;line-height:1;padding:0;margin-left:2px}.filter-tag-remove:hover{color:var(--error)}.filter-clear-all{background:none;border:none;color:var(--error);font-size:.7rem;cursor:pointer;padding:2px 4px}.filter-clear-all:hover{text-decoration:underline}.filter-section{margin-bottom:var(--spacing-md)}.filter-section-title{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.filter-section-clear{background:none;border:none;color:var(--text-secondary);font-size:.7rem;cursor:pointer}.filter-section-clear:hover{color:var(--error)}.filter-pills{display:flex;flex-wrap:wrap;gap:6px}.filter-pill{padding:4px 10px;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-xl);color:var(--text-secondary);font-size:.78rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-pill:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-secondary)}.filter-pill.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.filter-show-more{background:none;border:none;color:var(--text-secondary);font-size:.75rem;cursor:pointer;margin-top:var(--spacing-xs);padding:0}.filter-show-more:hover{color:var(--primary)}.filter-toggle{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.filter-toggle input{display:none}.filter-toggle-slider{position:relative;width:36px;height:20px;background:var(--bg-hover);border-radius:20px;transition:background var(--transition-fast);flex-shrink:0}.filter-toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:var(--text-secondary);border-radius:50%;transition:all var(--transition-fast)}.filter-toggle input:checked+.filter-toggle-slider{background:var(--success)}.filter-toggle input:checked+.filter-toggle-slider:after{left:18px;background:#fff}.filter-toggle-label{font-size:.8rem;color:var(--text-secondary)}.filter-brand-list{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto;scrollbar-width:thin}.filter-brand-item{display:flex;align-items:center;gap:var(--spacing-xs);padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.filter-brand-item:hover{background:var(--bg-hover)}.filter-brand-item.active{background:#2563eb1a}.filter-brand-item input{accent-color:var(--primary)}.filter-brand-name{font-size:.8rem;color:var(--text-secondary)}.filter-brand-item.active .filter-brand-name{color:var(--primary);font-weight:600}.filter-source-select{width:100%;padding:6px 10px;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.8rem;outline:none;cursor:pointer}.filter-source-select:focus{border-color:var(--primary)}.filter-mobile-action{display:none}.filter-apply-btn{width:100%;padding:var(--spacing-sm);background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer}.filter-apply-btn:hover{background:var(--primary-hover)}.product-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:all var(--transition-normal);cursor:pointer}.product-card:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-lg),0 0 0 1px var(--primary)}.product-image{aspect-ratio:1;background:linear-gradient(135deg,var(--bg-hover) 0%,var(--bg-dark) 100%);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--text-secondary)}.product-image img{width:100%;height:100%;object-fit:cover}.product-info{padding:var(--spacing-md)}.product-source{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm)}.product-source.vsforged{background:#7c3aed33;color:#a78bfa}.product-source.egowheels{background:#22c55e33;color:#86efac}.product-brand{font-size:.75rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.product-model{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-sm);line-height:1.3}.product-specs{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.spec-tag{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-hover);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-secondary)}.product-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-sm);border-top:1px solid var(--border)}.stock-badge{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;font-weight:500}.stock-badge.in-stock{color:var(--success)}.stock-badge.low-stock{color:var(--warning)}.stock-badge.out-of-stock{color:var(--error)}.stock-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.group-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:all var(--transition-normal);cursor:pointer}.group-card:hover{transform:translateY(-4px);border-color:var(--secondary);box-shadow:var(--shadow-lg),0 0 0 1px var(--secondary)}.group-image{aspect-ratio:1;background:linear-gradient(135deg,var(--bg-hover) 0%,var(--bg-dark) 100%);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--text-secondary);position:relative}.group-image img{width:100%;height:100%;object-fit:cover}.variant-badge{position:absolute;bottom:var(--spacing-sm);right:var(--spacing-sm);background:#7c3aede6;color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.group-info{padding:var(--spacing-md)}.group-brand{font-size:.75rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.group-model{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-sm);line-height:1.3}.group-specs{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.group-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-sm);border-top:1px solid var(--border)}.stock-total{font-size:.75rem;color:var(--text-secondary)}.stock-total strong{color:var(--text-primary);font-weight:600}.carousel-container{position:relative;overflow:hidden}.carousel-container img{transition:opacity .3s ease}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:#00000080;color:#fff;border:none;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease,background .2s ease;z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.carousel-container:hover .carousel-arrow{opacity:1}.carousel-arrow:hover{background:#000000bf}.carousel-arrow-left{left:8px}.carousel-arrow-right{right:8px}.carousel-dots{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:5px;z-index:3}.carousel-dot{width:7px;height:7px;border-radius:50%;background:#fff6;border:none;cursor:pointer;padding:0;transition:all .2s ease}.carousel-dot.active{background:#fff;transform:scale(1.3);box-shadow:0 0 4px #0000004d}.carousel-dot:hover{background:#fffc}.carousel-counter{position:absolute;top:8px;left:8px;background:#00000080;color:#fff;font-size:.7rem;padding:2px 8px;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3}.carousel-large{aspect-ratio:16/9;border-radius:var(--radius-md)}.carousel-large .carousel-arrow{width:40px;height:40px;font-size:1.5rem;opacity:.7}.carousel-large .carousel-dot{width:9px;height:9px}.carousel-large .carousel-counter{font-size:.8rem;padding:3px 10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary)}.btn-secondary:hover{background:var(--border)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border-radius:var(--radius-xl);max-width:600px;width:100%;max-height:80vh;overflow-y:auto;animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:var(--spacing-lg)}.modal-close{background:none;color:var(--text-secondary);font-size:1.5rem;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.ai-search-section{background:linear-gradient(135deg,#7c3aed1a,#2563eb1a);border:1px dashed var(--secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.ai-search-title{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600;margin-bottom:var(--spacing-md);color:var(--secondary)}.ai-search-form{display:flex;gap:var(--spacing-md)}.ai-search-input{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary)}.ai-search-input:focus{border-color:var(--secondary);outline:none}.trim-tabs{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding:4px;background:var(--bg-dark);border-radius:var(--radius-lg);border:1px solid var(--border)}.trim-tab{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.trim-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.trim-tab.active{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;border-color:transparent;font-weight:600;box-shadow:0 2px 8px #2563eb4d}@media(max-width:768px){.trim-tabs{gap:2px}.trim-tab{padding:var(--spacing-xs) var(--spacing-md);font-size:.8rem;flex:1;text-align:center;min-width:0}}.wheel-size-card{background:var(--bg-hover);padding:var(--spacing-md);border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:center;border:2px solid transparent;transition:all .25s cubic-bezier(.4,0,.2,1)}.wheel-size-card--clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.wheel-size-card--clickable:hover{background:#3b82f614;border-color:#3b82f640;transform:translate(4px)}.wheel-size-card--clickable:active{transform:translate(2px) scale(.99)}.wheel-size-card--selected{background:#3b82f626;border-color:var(--primary);border-left:4px solid var(--primary);box-shadow:0 2px 12px #3b82f626}.wheel-size-card--selected .spec-tag{background:#3b82f62e;color:var(--primary);font-weight:600}.wheel-size-card--clickable:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.view-mode-container{background:var(--bg-card);padding:var(--spacing-md) 0;border-bottom:1px solid var(--border)}.view-mode-switch{display:flex;gap:var(--spacing-sm);justify-content:center}.view-mode-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all var(--transition-fast)}.view-mode-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.view-mode-btn.active{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-color:var(--primary);color:#fff}.group-modal{max-width:800px}.modal-title h2{margin:var(--spacing-sm) 0 0;font-size:1.25rem}.group-modal-image{aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--bg-hover) 0%,var(--bg-dark) 100%);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg);overflow:hidden}.group-modal-image img{width:100%;height:100%;object-fit:contain}.group-modal-image .no-image{font-size:4rem;color:var(--text-secondary)}.group-modal-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-hover);border-radius:var(--radius-md)}.summary-item{text-align:center}.summary-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.summary-value{font-weight:600;color:var(--text-primary)}.summary-value.highlight{color:var(--success);font-size:1.25rem}.variants-section h3{font-size:1rem;margin-bottom:var(--spacing-md);color:var(--text-primary)}.variants-table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}.variants-table{width:100%;border-collapse:collapse;font-size:.875rem}.variants-table th,.variants-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border)}.variants-table th{background:var(--bg-hover);font-weight:600;color:var(--text-secondary);white-space:nowrap}.variants-table tbody tr:hover{background:var(--bg-hover)}.variants-table tbody tr:last-child td{border-bottom:none}.stock-cell{font-weight:600}.stock-cell.in-stock{color:var(--success)}.stock-cell.low-stock{color:var(--warning)}.stock-cell.out-of-stock{color:var(--error)}.empty-state{text-align:center;padding:var(--spacing-xl) * 2;color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:var(--spacing-md);opacity:.5}@media(max-width:768px){.header-content{flex-direction:column;gap:var(--spacing-md)}.hero h1{font-size:1.75rem}.hero-search-wrapper{flex-direction:column;border-radius:var(--radius-lg);gap:var(--spacing-sm);padding:var(--spacing-sm)}.hero-search-icon{display:none}.hero-search-input{width:100%;text-align:center}.hero-search-btn{width:100%;justify-content:center}.spec-panel-header{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.spec-panel-close{align-self:flex-end}.spec-panel-basics,.spec-sizes-buttons{flex-direction:column}.spec-size-btn{flex-direction:row;gap:var(--spacing-sm);min-width:100%}.search-bar{flex-direction:column}.search-input-wrapper{min-width:100%}.filter-select{width:100%}.products-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.group-card{border-radius:var(--radius-md)}.group-card:hover{transform:none}.group-image{aspect-ratio:3 / 2}.variant-badge{font-size:.65rem;padding:2px 6px;bottom:4px;right:4px}.group-info{padding:var(--spacing-xs) var(--spacing-sm)}.group-brand{font-size:.65rem;margin-bottom:1px}.group-model{font-size:.85rem;margin-bottom:var(--spacing-xs);line-height:1.2}.group-specs{gap:3px;margin-bottom:var(--spacing-xs)}.group-specs .spec-tag{font-size:.6rem;padding:1px 5px}.group-footer{padding-top:var(--spacing-xs);flex-wrap:wrap;gap:2px}.group-footer .stock-total{font-size:.65rem}.group-footer .stock-badge{font-size:.6rem;padding:1px 5px}.carousel-arrow{width:24px;height:24px;font-size:.7rem}.carousel-dots{gap:3px;bottom:4px}.carousel-dot{width:4px;height:4px}.ai-search-form{flex-direction:column}.products-layout{grid-template-columns:1fr}.filter-sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;max-height:80vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;transform:translateY(100%);transition:transform .3s ease;z-index:1000;padding-bottom:calc(var(--spacing-xl) + env(safe-area-inset-bottom))}.filter-sidebar.open{transform:translateY(0)}.filter-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border);margin-bottom:var(--spacing-md)}.filter-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:999}.filter-mobile-trigger{display:inline-flex!important;margin-left:auto}.filter-mobile-action{display:block;padding-top:var(--spacing-md);border-top:1px solid var(--border);margin-top:var(--spacing-md)}}@media(max-width:480px){.products-grid{gap:6px}.group-image{aspect-ratio:4 / 3}.group-info .product-source{display:none}.group-info{padding:6px 8px}.group-brand{font-size:.6rem;margin-bottom:0}.group-model{font-size:.8rem;margin-bottom:3px}.group-specs{margin-bottom:3px}.group-footer{padding-top:3px}.brand-quick-bar{gap:4px;padding:var(--spacing-xs) 0}.brand-quick-pill{font-size:.7rem;padding:3px 8px}.header{padding:8px 0 6px;background:#0f172ad9;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border-bottom:1px solid rgba(255,255,255,.06)}.header-content{flex-direction:column;gap:6px;padding:0 var(--spacing-sm);align-items:center}.logo{font-size:.85rem;white-space:nowrap;letter-spacing:.05em}.nav{width:100%;gap:0;background:#ffffff0f;border-radius:20px;padding:3px;justify-content:center}.nav::-webkit-scrollbar{display:none}.nav-link{flex:1;text-align:center;font-size:.7rem;padding:5px 4px;white-space:nowrap;flex-shrink:0;border-radius:16px;color:#ffffff80;transition:all .2s ease}.nav-link:hover{color:#fffc;background:transparent}.nav-link.active{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;font-weight:600;box-shadow:0 2px 8px #2563eb4d}}.photo-manager{display:grid;gap:var(--spacing-md)}.photo-manager-msg{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem}.photo-manager-msg--success{background:#22c55e1a;color:var(--success);border:1px solid var(--success)}.photo-manager-msg--error{background:#ef44441a;color:var(--error);border:1px solid var(--error)}.photo-manager-msg--info{background:#2563eb1a;color:var(--primary);border:1px solid var(--primary)}.photo-manager-search{display:flex;gap:var(--spacing-sm)}.photo-manager-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.photo-manager-product-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.photo-manager-product-item{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:.85rem;transition:all .15s ease}.photo-manager-product-item:hover{border-color:var(--primary);background:#2563eb1a}.photo-manager-product-item--active{border-color:var(--primary);background:#2563eb33;box-shadow:0 0 0 1px var(--primary)}.photo-manager-badge{display:inline-block;background:var(--primary);color:#fff;font-size:.7rem;padding:1px 6px;border-radius:999px;margin-left:4px}.photo-manager-detail{border-top:1px solid var(--border);padding-top:var(--spacing-md)}.photo-manager-detail-title{margin-bottom:var(--spacing-md);font-size:1rem}.photo-manager-upload{display:flex;gap:var(--spacing-sm);align-items:center;margin-bottom:var(--spacing-md)}.photo-manager-upload-btn{white-space:nowrap;cursor:pointer}.photo-manager-empty{text-align:center;color:var(--text-secondary);padding:var(--spacing-xl) 0;font-size:.9rem}.photo-manager-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-sm)}.photo-manager-card{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s ease}.photo-manager-card:hover{border-color:var(--primary)}.photo-manager-card-img{position:relative;aspect-ratio:1;overflow:hidden;background:var(--bg-dark)}.photo-manager-card-img img{width:100%;height:100%;object-fit:cover}.photo-manager-card-delete{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#ef4444d9;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;opacity:0;transition:opacity .15s ease}.photo-manager-card:hover .photo-manager-card-delete{opacity:1}.photo-manager-card-delete:hover{background:var(--error)}.photo-manager-card-info{padding:var(--spacing-xs) var(--spacing-sm);display:flex;flex-direction:column;gap:2px}.photo-manager-card-name{font-size:.75rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-manager-card-meta{font-size:.65rem;color:var(--text-secondary)}.blog-tip-card{position:relative;background:linear-gradient(135deg,#1e293bf2,#0f172afa);border-radius:var(--radius-xl);padding:var(--spacing-xl) var(--spacing-lg);margin:var(--spacing-xl) 0;border:1px solid rgba(124,58,237,.15);overflow:hidden;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0a;animation:blogTipFadeIn .6s ease-out}@keyframes blogTipFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.blog-tip-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f97316,#ec4899,#8b5cf6,#06b6d4);background-size:200% 100%;animation:blogTipGradientShift 4s ease infinite}@keyframes blogTipGradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.blog-tip-card:after{content:"";position:absolute;top:-40%;right:-10%;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.06) 0%,transparent 70%);pointer-events:none}.blog-tip-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);position:relative;z-index:1}.blog-tip-icon{width:44px;height:44px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#f9731626,#8b5cf626);border:1px solid rgba(249,115,22,.2);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.blog-tip-title-group{flex:1;min-width:0}.blog-tip-title{font-size:1.05rem;font-weight:700;margin:0;line-height:1.3;background:linear-gradient(135deg,#f8fafc,#cbd5e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.blog-tip-subtitle{font-size:.75rem;color:var(--text-secondary);margin-top:2px;display:flex;align-items:center;gap:var(--spacing-xs)}.blog-tip-label{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:linear-gradient(135deg,#f973161f,#8b5cf61f);border:1px solid rgba(249,115,22,.2);border-radius:999px;font-size:.65rem;font-weight:600;color:#f97316;letter-spacing:.02em;text-transform:uppercase}.blog-tip-body{position:relative;z-index:1;font-size:.9rem;line-height:1.9;color:var(--text-secondary);white-space:pre-line;padding-left:var(--spacing-md);border-left:2px solid rgba(139,92,246,.2)}.blog-tip-body p{margin-bottom:var(--spacing-md)}.blog-tip-body p:last-child{margin-bottom:0}.blog-tip-footer{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid rgba(124,58,237,.12)}.blog-tip-brand{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.75rem;color:var(--text-secondary);font-weight:500}.blog-tip-brand-icon{width:28px;height:28px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:.8rem}.blog-tip-brand-sep{color:#94a3b866;margin:0 2px}.blog-tip-tags{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.blog-tip-tag{padding:2px 10px;background:#2563eb14;border:1px solid rgba(37,99,235,.15);border-radius:999px;font-size:.65rem;color:var(--primary);font-weight:500;transition:all .2s ease;cursor:default}.blog-tip-tag:hover{background:#2563eb29;border-color:#2563eb4d;transform:translateY(-1px)}@media(max-width:768px){.blog-tip-card{padding:var(--spacing-lg) var(--spacing-md);margin:var(--spacing-lg) 0;border-radius:var(--radius-lg)}.blog-tip-header{gap:var(--spacing-sm)}.blog-tip-icon{width:36px;height:36px;font-size:1rem}.blog-tip-title{font-size:.95rem}.blog-tip-body{font-size:.85rem;line-height:1.8;padding-left:var(--spacing-sm)}.blog-tip-footer{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.blog-tip-tags{margin-top:var(--spacing-xs)}}
