:root{font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#1a1a2e;background-color:#f0f2f5}body{margin:0;min-width:320px;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--sidebar-w: 240px;--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #eef2ff;--success: #16a34a;--success-bg: #dcfce7;--warning: #d97706;--warning-bg: #fef3c7;--danger: #dc2626;--danger-bg: #fee2e2;--info: #2563eb;--info-bg: #dbeafe;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.5}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--gray-900);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-header{padding:1.25rem 1rem;border-bottom:1px solid var(--gray-700);display:flex;align-items:center;gap:.65rem}.sidebar-logo{width:38px;height:38px;border-radius:8px;object-fit:cover;flex-shrink:0}.sidebar-header h2{font-size:1.15rem;font-weight:700}.sidebar-nav{flex:1;padding:.5rem 0}.nav-section{display:block;padding:.75rem 1rem .25rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400);font-weight:600}.nav-link{display:block;padding:.5rem 1rem;color:var(--gray-300);text-decoration:none;font-size:.875rem;transition:background .15s,color .15s;border-left:3px solid transparent}.nav-link:hover{background:var(--gray-800);color:#fff}.nav-link.active{background:var(--gray-800);color:#fff;border-left-color:var(--primary);font-weight:600}.sidebar-footer{padding:.75rem 1rem;border-top:1px solid var(--gray-700);font-size:.8rem}.sidebar-footer .user-email{display:block;color:var(--gray-400);margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis}.sidebar-footer .btn-logout{width:100%;padding:.4rem;background:var(--gray-700);color:var(--gray-300);border:none;border-radius:var(--radius);cursor:pointer;font-size:.8rem}.sidebar-footer .btn-logout:hover{background:var(--danger);color:#fff}.main-content{flex:1;margin-left:var(--sidebar-w);padding:1.5rem 2rem;min-height:100vh}.page{max-width:1200px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.section-header{display:flex;align-items:center;justify-content:space-between;margin:2rem 0 1rem}.section-header h2{font-size:1.15rem;font-weight:600}.btn-primary{background:var(--primary);color:#fff;border:none;padding:.5rem 1.25rem;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{background:var(--gray-200);color:var(--gray-700);border:none;padding:.5rem 1.25rem;border-radius:var(--radius);font-size:.875rem;cursor:pointer}.btn-cancel:hover{background:var(--gray-300)}.btn-back{background:none;border:none;color:var(--primary);font-size:.9rem;cursor:pointer;margin-bottom:1rem;font-weight:500}.btn-back:hover{text-decoration:underline}.btn-sm{padding:.25rem .5rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;background:var(--gray-100)}.btn-sm:hover{background:var(--gray-200)}.btn-sm.btn-edit{background:var(--primary-light)}.btn-sm.btn-edit:hover{background:#c7d2fe}.btn-sm.btn-delete{background:var(--danger-bg)}.btn-sm.btn-delete:hover{background:#fca5a5}.btn-sm.btn-primary{background:var(--primary);color:#fff}.btn-edit{background:var(--primary-light);border:none;padding:.3rem .6rem;border-radius:4px;cursor:pointer}.btn-delete{background:var(--danger-bg);border:none;padding:.3rem .6rem;border-radius:4px;cursor:pointer}.search-bar{margin-bottom:1rem}.search-bar input{width:100%;padding:.6rem 1rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem;background:#fff}.search-bar input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.filter-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-row label{font-weight:600;font-size:.85rem;color:var(--gray-600)}.filter-row select{padding:.4rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.85rem;background:#fff}.tab-buttons{display:flex;gap:2px;margin-left:auto;background:var(--gray-200);border-radius:var(--radius);padding:2px}.tab-buttons button{padding:.4rem 1rem;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--gray-600)}.tab-buttons button.active{background:#fff;color:var(--gray-900);box-shadow:var(--shadow)}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);font-size:.875rem}.data-table thead{background:var(--gray-50)}.data-table th{padding:.6rem .75rem;text-align:left;font-weight:600;color:var(--gray-600);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--gray-200)}.data-table td{padding:.6rem .75rem;border-bottom:1px solid var(--gray-100);color:var(--gray-700)}.data-table tbody tr:hover{background:var(--gray-50)}.data-table tfoot td{padding:.6rem .75rem;background:var(--gray-50);font-weight:600;border-top:2px solid var(--gray-200)}.actions{display:flex;gap:.35rem}.row-warning{background:var(--warning-bg)!important}code.sku{font-family:JetBrains Mono,Fira Code,monospace;background:var(--gray-100);padding:.15rem .4rem;border-radius:4px;font-size:.8rem;color:var(--gray-700)}.badge{display:inline-block;padding:.15rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;background:var(--gray-100);color:var(--gray-600);margin-right:.25rem}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.product-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:box-shadow .2s,transform .15s;display:flex;flex-direction:column}.product-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.product-card-img{height:160px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;overflow:hidden}.product-card-img img{width:100%;height:100%;object-fit:cover}.no-img{font-size:3rem;opacity:.3}.no-img-lg{font-size:5rem;opacity:.2}.product-card-body{padding:.75rem;flex:1}.product-card-body h3{font-size:.95rem;font-weight:600;margin-bottom:.25rem;color:var(--gray-900)}.product-brand{font-size:.8rem;color:var(--gray-500);margin-bottom:.4rem}.product-categories{display:flex;flex-wrap:wrap;gap:.2rem}.product-card-actions{padding:.5rem .75rem;border-top:1px solid var(--gray-100);display:flex;gap:.35rem;justify-content:flex-end}.product-detail-header{display:flex;gap:1.5rem;background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);margin-bottom:1.5rem}.product-detail-img{width:200px;height:200px;background:var(--gray-100);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.product-detail-img img{width:100%;height:100%;object-fit:cover}.product-detail-info{flex:1}.product-detail-info h1{font-size:1.5rem;margin-bottom:.5rem}.product-detail-info p{margin-bottom:.35rem;color:var(--gray-600)}.inline-form{display:flex;gap:.5rem;align-items:flex-end;background:#fff;padding:1rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1rem;flex-wrap:wrap}.inline-form input,.inline-form select{padding:.45rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.875rem}.inline-form button{padding:.45rem 1rem;border-radius:var(--radius);border:none;cursor:pointer;font-size:.875rem;font-weight:600;background:var(--primary);color:#fff}.inline-form button:hover{background:var(--primary-hover)}.inline-form .btn-cancel{background:var(--gray-200);color:var(--gray-700)}.detail-form{background:#fff;padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem}.detail-form h3{margin-bottom:1rem;font-size:1.1rem}.detail-form.compact{padding:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-weight:600;font-size:.85rem;color:var(--gray-600);margin-bottom:.3rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-actions{display:flex;gap:.75rem;margin-top:1rem}.checkbox-group{display:flex;flex-wrap:wrap;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.35rem;padding:.3rem .6rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);font-size:.85rem;cursor:pointer}.checkbox-label:has(input:checked){background:var(--primary-light);border-color:var(--primary)}.checkbox-label input[type=checkbox]{width:auto}.img-preview{width:120px;height:120px;object-fit:cover;border-radius:var(--radius);margin-top:.5rem;border:1px solid var(--gray-200)}.autocomplete-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-height:250px;overflow-y:auto;z-index:50;list-style:none}.autocomplete-list li{padding:.5rem .75rem;cursor:pointer;font-size:.85rem;border-bottom:1px solid var(--gray-100)}.autocomplete-list li:hover{background:var(--primary-light)}.autocomplete-list li strong{color:var(--primary)}.autocomplete-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem}.autocomplete-thumb{width:36px;height:36px;object-fit:cover;border-radius:4px;flex-shrink:0;border:1px solid var(--gray-200)}.autocomplete-thumb-empty{width:36px;height:36px;flex-shrink:0;border-radius:4px;background:var(--gray-100);border:1px dashed var(--gray-300)}.autocomplete-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.autocomplete-meta{font-size:.75rem;color:var(--gray-500)}.stock-ok{color:var(--success);font-weight:600}.stock-zero{color:var(--danger);font-weight:600}.sale-items-thumbs{display:flex;flex-wrap:wrap;gap:.35rem}.sale-item-chip{position:relative;display:inline-flex;align-items:center}.sale-item-thumb{width:32px;height:32px;object-fit:cover;border-radius:4px;border:1px solid var(--gray-200)}.sale-item-thumb-empty{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:4px;background:var(--gray-100);border:1px dashed var(--gray-300);font-size:.7rem}.sale-item-qty{position:absolute;bottom:-2px;right:-4px;background:var(--primary);color:#fff;font-size:.6rem;font-weight:700;padding:0 .25rem;border-radius:8px;line-height:1.3;min-width:14px;text-align:center}.cart-thumb{width:40px;height:40px;object-fit:cover;border-radius:6px;border:1px solid var(--gray-200);display:block}.cart-thumb-empty{display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:1px dashed var(--gray-300);font-size:.75rem}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);text-align:center}.stat-number{display:block;font-size:1.75rem;font-weight:700;color:var(--primary)}.stat-label{display:block;font-size:.8rem;color:var(--gray-500);margin-top:.25rem}.report-section{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);margin-bottom:1.5rem}.report-section h2{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--gray-800)}.bar-chart{display:flex;flex-direction:column;gap:.5rem}.bar-item{display:grid;grid-template-columns:140px 1fr 120px;align-items:center;gap:.5rem}.bar-label{font-size:.8rem;color:var(--gray-600);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{height:22px;background:var(--gray-100);border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:var(--primary);border-radius:4px;min-width:2px;transition:width .3s}.bar-fill-accent{background:var(--success)}.bar-value{font-size:.78rem;color:var(--gray-500);font-weight:500}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.modal-content{background:#fff;border-radius:var(--radius);padding:1.5rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-content h3{margin-bottom:1rem}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-900) 0%,var(--primary) 100%)}.auth-form{background:#fff;padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:400px}.auth-logo{text-align:center;margin-bottom:1rem}.auth-logo img{width:80px;height:80px;border-radius:16px;object-fit:cover;box-shadow:var(--shadow)}.auth-form h2{text-align:center;margin-bottom:1.5rem;color:var(--gray-900)}.auth-form .form-group{margin-bottom:1rem}.auth-form .form-group label{display:block;font-weight:600;font-size:.85rem;color:var(--gray-600);margin-bottom:.3rem}.auth-form .form-group input{width:100%;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem}.auth-form .form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.auth-form button[type=submit]{width:100%;padding:.6rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;margin-top:.5rem}.auth-form button[type=submit]:hover{background:var(--primary-hover)}.auth-form p{text-align:center;margin-top:1rem;font-size:.85rem;color:var(--gray-500)}.auth-form p a{color:var(--primary);text-decoration:none;font-weight:600}.auth-form p a:hover{text-decoration:underline}.error-message{background:var(--danger-bg);color:var(--danger);padding:.6rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.875rem;font-weight:500}.loading{text-align:center;color:var(--gray-400);padding:2rem}.empty-state{text-align:center;color:var(--gray-400);padding:3rem 1rem;font-size:.95rem}@media(max-width:768px){.sidebar{width:200px}:root{--sidebar-w: 200px}.main-content{padding:1rem}.card-grid{grid-template-columns:1fr}.bar-item{grid-template-columns:80px 1fr 80px}.product-detail-header{flex-direction:column}.product-detail-img{width:100%;height:180px}}.variant-list{display:flex;flex-direction:column;gap:1rem}.variant-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.variant-card-top{display:flex;gap:1rem;padding:1rem;align-items:flex-start}.variant-thumb{width:90px;height:90px;border-radius:var(--radius);background:var(--gray-100);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;cursor:pointer;position:relative}.variant-thumb img{width:100%;height:100%;object-fit:cover}.img-count{position:absolute;bottom:2px;right:2px;background:#000000a6;color:#fff;font-size:.65rem;padding:.1rem .35rem;border-radius:4px;font-weight:600}.variant-info{flex:1;min-width:0}.variant-info code{display:inline-block;margin-bottom:.35rem}.variant-info p{font-size:.85rem;color:var(--gray-600);margin-bottom:.25rem}.variant-images-row{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.5rem}.mini-thumb{width:44px;height:44px;border-radius:4px;overflow:hidden;position:relative;border:1px solid var(--gray-200)}.mini-thumb img{width:100%;height:100%;object-fit:cover}.mini-thumb-delete{position:absolute;top:-2px;right:-2px;width:16px;height:16px;font-size:.55rem;border:none;background:var(--danger);color:#fff;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1;padding:0}.mini-thumb:hover .mini-thumb-delete{display:flex}.mini-thumb-edit{display:flex;align-items:center;gap:.3rem;background:#fff;border:1px solid var(--primary);border-radius:var(--radius);padding:.25rem .4rem;box-shadow:0 0 0 3px #4f46e51a}.mini-thumb-edit-input{width:220px;padding:.2rem .4rem;border:1px solid var(--gray-300);border-radius:4px;font-size:.78rem;font-family:JetBrains Mono,Fira Code,monospace}.mini-thumb-edit-input:focus{outline:none;border-color:var(--primary)}.variant-actions{display:flex;flex-direction:column;gap:.35rem;flex-shrink:0}.variant-image-form{padding:0 1rem 1rem}.variant-image-form textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.85rem;font-family:inherit;resize:vertical;margin-bottom:.5rem}.variant-image-form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.gallery-modal{background:#fff;border-radius:var(--radius);padding:1.5rem;max-width:700px;width:90%;position:relative;text-align:center}.gallery-close{position:absolute;top:.75rem;right:.75rem;background:var(--gray-100);border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:1rem}.gallery-close:hover{background:var(--gray-200)}.gallery-modal h3{margin-bottom:1rem;font-size:1.1rem}.gallery-main{display:flex;align-items:center;gap:.75rem;justify-content:center}.gallery-arrow{background:var(--gray-100);border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1rem;flex-shrink:0}.gallery-arrow:hover{background:var(--gray-200)}.gallery-arrow:disabled{opacity:.3;cursor:not-allowed}.gallery-img{max-width:500px;max-height:400px;object-fit:contain;border-radius:var(--radius)}.gallery-dots{display:flex;justify-content:center;gap:.4rem;margin-top:.75rem}.dot{width:10px;height:10px;border-radius:50%;background:var(--gray-300);cursor:pointer}.dot.active{background:var(--primary)}.gallery-counter{margin-top:.5rem;font-size:.8rem;color:var(--gray-400)}.barcode-label{display:flex;align-items:center;gap:.4rem;padding:.25rem}.barcode-label canvas{width:100px;height:100px;image-rendering:pixelated;flex-shrink:0}.barcode-label-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;text-align:left}.barcode-label-name{font-size:.7rem;font-weight:700;color:var(--gray-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.barcode-label-detail{font-size:.6rem;color:var(--gray-600);font-weight:700}.barcode-label-price{font-size:.8rem;font-weight:700;color:var(--gray-900)}.barcode-label-sku{font-size:.5rem;font-family:monospace;color:var(--gray-500);font-weight:700}.barcode-preview{background:#fff;border:1px dashed var(--gray-300);border-radius:var(--radius);padding:.75rem;margin:1rem auto;max-width:280px}.catalog{min-height:100vh;background:var(--gray-50)}.catalog-header{background:#fff;box-shadow:0 1px 4px #00000014;position:sticky;top:0;z-index:100}.catalog-header-inner{max-width:1200px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem}.catalog-logo{font-size:1.15rem;font-weight:800;color:var(--gray-900);white-space:nowrap;display:flex;align-items:center;gap:.4rem}.catalog-logo-img{width:32px;height:32px;border-radius:6px;object-fit:cover}.catalog-search{flex:1;min-width:0}.catalog-search input{width:100%;padding:.5rem .85rem;border:1px solid var(--gray-300);border-radius:50px;font-size:.9rem;background:var(--gray-50);transition:border-color .15s}.catalog-search input:focus{outline:none;border-color:var(--primary);background:#fff}.catalog-header-actions{display:flex;gap:.5rem;flex-shrink:0}.catalog-filter-btn,.catalog-cart-btn{background:var(--gray-100);border:none;padding:.5rem .85rem;border-radius:50px;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--gray-700);position:relative;white-space:nowrap}.catalog-filter-btn:hover,.catalog-cart-btn:hover{background:var(--gray-200)}.cart-badge{background:var(--primary);color:#fff;font-size:.65rem;font-weight:700;padding:.1rem .4rem;border-radius:10px;position:absolute;top:-2px;right:-2px;min-width:16px;text-align:center}.catalog-filters{max-width:1200px;margin:0 auto;padding:.5rem 1rem .75rem;display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap;border-top:1px solid var(--gray-100)}.catalog-filter-group{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:120px}.catalog-filter-group label{font-size:.7rem;font-weight:600;color:var(--gray-500);text-transform:uppercase}.catalog-filter-group select{padding:.4rem .5rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.85rem;background:#fff}.catalog-filter-clear{background:none;border:none;color:var(--primary);font-size:.8rem;cursor:pointer;font-weight:600;padding:.4rem 0}.catalog-main{max-width:1200px;margin:0 auto;padding:1rem}.catalog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.catalog-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 1px 3px #0000000f;cursor:pointer;transition:box-shadow .2s,transform .15s}.catalog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.catalog-card:active{transform:scale(.98)}.catalog-card-img{aspect-ratio:1;background:var(--gray-100);overflow:hidden;display:flex;align-items:center;justify-content:center}.catalog-card-img img{width:100%;height:100%;object-fit:cover}.catalog-no-img{font-size:2.5rem;opacity:.2}.catalog-card-body{padding:.6rem .7rem}.catalog-card-brand{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-400);font-weight:600}.catalog-card-body h3{font-size:.85rem;font-weight:600;color:var(--gray-900);margin:.15rem 0 .25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catalog-card-tags{display:flex;flex-wrap:wrap;gap:.2rem;margin-bottom:.3rem}.catalog-tag{font-size:.6rem;padding:.1rem .35rem;background:var(--primary-light);color:var(--primary);border-radius:4px;font-weight:600}.catalog-card-price{font-size:.9rem;font-weight:700;color:var(--gray-900)}.catalog-card-color{display:inline-block;font-size:.75rem;color:var(--gray-500);font-weight:500;margin-bottom:.15rem}.catalog-card-sizes{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.3rem}.catalog-size-chip{font-size:.65rem;padding:.1rem .35rem;background:var(--gray-100);border-radius:4px;color:var(--gray-600);font-weight:600}.catalog-loading,.catalog-empty{text-align:center;padding:3rem 1rem;color:var(--gray-400);font-size:.95rem}.catalog-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center}.catalog-detail{background:#fff;border-radius:16px 16px 0 0;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.catalog-close{position:absolute;top:.75rem;right:.75rem;background:var(--gray-100);border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1rem;z-index:10}.catalog-close:hover{background:var(--gray-200)}.catalog-detail-gallery{background:var(--gray-100)}.catalog-detail-img{width:100%;max-height:350px;object-fit:contain;display:block}.catalog-detail-no-img{width:100%;height:200px;display:flex;align-items:center;justify-content:center;font-size:4rem;opacity:.15}.catalog-detail-thumbs{display:flex;gap:.35rem;padding:.5rem;overflow-x:auto}.catalog-detail-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;border:2px solid transparent;cursor:pointer;flex-shrink:0}.catalog-detail-thumb.active{border-color:var(--primary)}.catalog-detail-info{padding:1rem 1.25rem 1.5rem}.catalog-detail-info h2{font-size:1.25rem;margin:.25rem 0 .35rem}.catalog-detail-section{margin-bottom:1rem}.catalog-detail-section>label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-400);font-weight:600;margin-bottom:.35rem}.catalog-color-list{display:flex;flex-wrap:wrap;gap:.3rem}.catalog-color-chip{padding:.3rem .75rem;background:var(--gray-100);border:2px solid transparent;border-radius:50px;font-size:.85rem;font-weight:500;color:var(--gray-700);cursor:pointer;transition:all .15s ease}.catalog-color-chip:hover{background:var(--gray-200)}.catalog-color-chip.active{border-color:var(--primary);background:#4338ca14;color:var(--primary);font-weight:600}.catalog-size-list{display:flex;flex-wrap:wrap;gap:.4rem}.catalog-size-chip-btn{min-width:2.5rem;padding:.35rem .6rem;background:var(--gray-100);border:2px solid transparent;border-radius:var(--radius);font-size:.85rem;font-weight:600;color:var(--gray-700);cursor:pointer;text-align:center;transition:all .15s ease}.catalog-size-chip-btn:hover{background:var(--gray-200)}.catalog-size-chip-btn.active{border-color:var(--primary);background:#4338ca14;color:var(--primary)}.catalog-detail-price{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.catalog-add-cart-btn{display:block;width:100%;padding:.75rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s ease}.catalog-add-cart-btn:hover{background:var(--primary-hover)}.catalog-add-cart-btn:active{transform:scale(.98)}.catalog-select-hint{text-align:center;color:var(--gray-400);font-size:.9rem;padding:.5rem 0}.catalog-qty-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.catalog-qty-control{display:flex;align-items:center;border:2px solid var(--gray-200);border-radius:var(--radius);overflow:hidden}.catalog-qty-btn{width:2.5rem;height:2.5rem;background:var(--gray-50);border:none;font-size:1.2rem;font-weight:700;color:var(--gray-700);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s}.catalog-qty-btn:hover{background:var(--gray-200)}.catalog-qty-btn:active{background:var(--gray-300)}.catalog-qty-input{width:3rem;text-align:center;border:none;border-left:2px solid var(--gray-200);border-right:2px solid var(--gray-200);font-size:1.05rem;font-weight:600;color:var(--gray-800);padding:.4rem 0;-moz-appearance:textfield;appearance:textfield}.catalog-qty-input::-webkit-outer-spin-button,.catalog-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.catalog-stock-hint{font-weight:400;font-size:.8rem;color:var(--gray-400);margin-left:.25rem}.catalog-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:#fff;color:var(--gray-800);padding:.85rem 1.5rem;border-radius:14px;box-shadow:0 8px 32px #0000002e;display:flex;align-items:center;gap:.75rem;z-index:99999;animation:toast-in .35s cubic-bezier(.34,1.56,.64,1) forwards;max-width:90vw}.catalog-toast-icon{font-size:1.5rem;flex-shrink:0}.catalog-toast strong{font-size:.95rem;display:block}.catalog-toast p{margin:.15rem 0 0;font-size:.8rem;color:var(--gray-500)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(30px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.catalog-drawer{position:fixed;top:0;right:0;width:100%;max-width:420px;height:100%;background:#fff;box-shadow:-4px 0 20px #00000026;display:flex;flex-direction:column;animation:slideRight .25s ease;z-index:210}@keyframes slideRight{0%{transform:translate(100%)}to{transform:translate(0)}}.catalog-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--gray-100)}.catalog-drawer-header h3{font-size:1.1rem}.catalog-cart-items{flex:1;overflow-y:auto;padding:.5rem}.catalog-cart-item{display:flex;align-items:center;gap:.6rem;padding:.6rem;border-bottom:1px solid var(--gray-100)}.catalog-cart-item-img{width:50px;height:50px;border-radius:6px;background:var(--gray-100);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.catalog-cart-item-img img{width:100%;height:100%;object-fit:cover}.catalog-cart-item-img span{font-size:1.2rem;opacity:.3}.catalog-cart-item-info{flex:1;min-width:0;display:flex;flex-direction:column}.catalog-cart-item-info strong{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.catalog-cart-item-info span{font-size:.75rem;color:var(--gray-500)}.catalog-cart-item-price{font-weight:700!important;color:var(--gray-900)!important;font-size:.85rem!important}.catalog-cart-item-actions{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.catalog-cart-item-actions button{width:28px;height:28px;border:1px solid var(--gray-300);background:#fff;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center}.catalog-cart-item-actions button:hover{background:var(--gray-100)}.catalog-cart-item-actions>span{font-weight:600;min-width:20px;text-align:center}.catalog-cart-remove{color:var(--danger)!important;border-color:var(--danger-bg)!important;margin-left:.3rem}.catalog-cart-footer{padding:1rem 1.25rem;border-top:1px solid var(--gray-200);background:var(--gray-50)}.catalog-cart-total{display:flex;justify-content:space-between;font-size:1.1rem;margin-bottom:.75rem}.catalog-cart-total strong{font-size:1.25rem;color:var(--gray-900)}.catalog-cart-note{text-align:center;font-size:.75rem;color:var(--gray-400);margin-top:.5rem}.catalog-btn-primary{width:100%;padding:.7rem;background:var(--primary);color:#fff;border:none;border-radius:50px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .15s}.catalog-btn-primary:hover{background:var(--primary-hover)}.catalog-btn-primary:active{transform:scale(.98)}.catalog-checkout{padding:1rem 1.25rem;flex:1;display:flex;flex-direction:column}.catalog-back{background:none;border:none;color:var(--primary);font-size:.85rem;cursor:pointer;font-weight:600;padding:0;margin-bottom:.75rem;text-align:left}.catalog-checkout h4{font-size:1.1rem;margin-bottom:1rem}.catalog-field{margin-bottom:.85rem}.catalog-field label{display:block;font-size:.75rem;font-weight:600;color:var(--gray-600);margin-bottom:.2rem}.catalog-field input,.catalog-field select{width:100%;padding:.55rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem}.catalog-field input:focus,.catalog-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.catalog-error{background:var(--danger-bg);color:var(--danger);padding:.5rem .75rem;border-radius:var(--radius);font-size:.8rem;margin-bottom:.75rem}.catalog-checkout-summary{background:var(--gray-50);border-radius:var(--radius);padding:.75rem;margin:1rem 0}.catalog-checkout-total{font-size:1.1rem}.catalog-success{display:flex;flex-direction:column;align-items:center;padding:2rem 1.25rem;text-align:center;gap:.5rem}.catalog-success-icon{font-size:3rem}.catalog-success-code{font-family:JetBrains Mono,monospace;font-size:1.3rem;font-weight:700;color:var(--primary);background:var(--primary-light);padding:.4rem 1rem;border-radius:var(--radius)}.catalog-success-expires{font-size:.85rem;color:var(--gray-500);margin-bottom:.5rem}@media(min-width:600px){.catalog-grid{grid-template-columns:repeat(3,1fr);gap:1rem}.catalog-card-body h3{font-size:.9rem}.catalog-detail{border-radius:16px;max-width:600px;max-height:85vh;margin:auto}.catalog-overlay{align-items:center}}@media(min-width:900px){.catalog-grid{grid-template-columns:repeat(4,1fr)}.catalog-card-body{padding:.75rem .85rem}.catalog-card-body h3{font-size:.95rem}.catalog-card-price{font-size:1rem}.catalog-detail{max-width:700px;display:grid;grid-template-columns:1fr 1fr}.catalog-detail-gallery{border-radius:16px 0 0 16px}.catalog-detail-img{max-height:500px;height:100%}}@media(max-width:400px){.catalog-logo{font-size:.95rem}.catalog-filter-btn span,.catalog-cart-btn{padding:.4rem .6rem;font-size:.8rem}.catalog-search input{padding:.4rem .65rem;font-size:.85rem}}.home-page{min-height:100vh;background:#f8fafc}.home-header{background:#fff;box-shadow:0 1px 4px #00000014;position:sticky;top:0;z-index:50}.home-header-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem}.home-brand{display:flex;align-items:center;gap:.5rem;font-size:1.15rem;font-weight:800;color:var(--gray-900);cursor:pointer}.home-logo{width:36px;height:36px;border-radius:8px;object-fit:cover}.home-nav-btn{background:var(--primary);color:#fff;border:none;padding:.5rem 1.2rem;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s}.home-nav-btn:hover{background:var(--primary-dark, #4338ca)}.home-carousel{max-width:1100px;margin:2rem auto;padding:0 1rem}.home-carousel-title{font-size:1.6rem;font-weight:800;color:var(--gray-900);text-align:center;margin-bottom:1.25rem}.home-carousel-viewport{position:relative;overflow:hidden;border-radius:16px;box-shadow:0 4px 24px #0000001a;background:#fff}.home-carousel-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}.home-carousel-slide{min-width:100%;display:flex;cursor:pointer}.home-slide-img{flex:1;min-height:350px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;overflow:hidden}.home-slide-img img{width:100%;height:100%;object-fit:cover;min-height:350px}.home-slide-placeholder{font-size:4rem;color:#d1d5db}.home-slide-info{flex:1;padding:2.5rem 2rem;display:flex;flex-direction:column;justify-content:center;gap:.5rem}.home-slide-brand{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);font-weight:700}.home-slide-info h3{font-size:1.6rem;font-weight:800;color:var(--gray-900);line-height:1.2}.home-slide-price{font-size:1.3rem;font-weight:700;color:var(--gray-700);margin:.5rem 0}.home-slide-cta{align-self:flex-start;background:var(--primary);color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;margin-top:.5rem;transition:background .2s}.home-slide-cta:hover{background:var(--primary-dark, #4338ca)}.home-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffd9;border:none;width:44px;height:44px;border-radius:50%;font-size:1.5rem;font-weight:700;color:var(--gray-700);cursor:pointer;box-shadow:0 2px 8px #0000001f;z-index:5;transition:background .2s;display:flex;align-items:center;justify-content:center}.home-carousel-arrow:hover{background:#fff}.home-arrow-left{left:12px}.home-arrow-right{right:12px}.home-carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}.home-dot{width:10px;height:10px;border-radius:50%;border:none;background:#d1d5db;cursor:pointer;transition:background .2s,transform .2s}.home-dot.active{background:var(--primary);transform:scale(1.3)}.home-cta-section{text-align:center;padding:3rem 1rem;max-width:600px;margin:0 auto}.home-cta-section h3{font-size:1.3rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.home-cta-section p{color:var(--gray-500);margin-bottom:1.25rem}.home-cta-btn{background:var(--gray-900);color:#fff;border:none;padding:.7rem 2rem;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .2s}.home-cta-btn:hover{background:var(--gray-700)}.home-empty-carousel{text-align:center;padding:4rem 1rem;color:var(--gray-500)}.home-empty-carousel .home-nav-btn{margin-top:1rem}.home-loading{text-align:center;padding:4rem 1rem;color:var(--gray-400)}@media(max-width:700px){.home-carousel-slide{flex-direction:column}.home-slide-img,.home-slide-img img{min-height:220px}.home-slide-info{padding:1.25rem 1rem 1.5rem}.home-slide-info h3{font-size:1.2rem}.home-slide-price{font-size:1.1rem}.home-carousel-title{font-size:1.2rem}.home-carousel-arrow{width:36px;height:36px;font-size:1.2rem}}.carousel-search-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 24px #0000001f;z-index:20;max-height:280px;overflow-y:auto;margin-top:4px}.carousel-search-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;cursor:pointer;transition:background .15s}.carousel-search-item:hover{background:#f3f4f6}.carousel-search-thumb{width:40px;height:40px;border-radius:6px;overflow:hidden;background:#f3f4f6;display:flex;align-items:center;justify-content:center;flex-shrink:0}.carousel-search-thumb img{width:100%;height:100%;object-fit:cover}.carousel-search-brand{display:block;font-size:.75rem;color:var(--gray-400)}.carousel-admin-list{display:flex;flex-direction:column;gap:.5rem}.carousel-admin-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.carousel-admin-order{display:flex;flex-direction:column;align-items:center;gap:2px}.carousel-order-btn{background:none;border:1px solid #d1d5db;border-radius:4px;width:24px;height:20px;font-size:.65rem;cursor:pointer;color:var(--gray-500);display:flex;align-items:center;justify-content:center;transition:background .15s}.carousel-order-btn:hover:not(:disabled){background:#e5e7eb}.carousel-order-btn:disabled{opacity:.3;cursor:default}.carousel-order-num{font-size:.75rem;font-weight:700;color:var(--gray-400)}.carousel-admin-thumb{width:50px;height:50px;border-radius:8px;overflow:hidden;background:#f3f4f6;display:flex;align-items:center;justify-content:center;flex-shrink:0}.carousel-admin-thumb img{width:100%;height:100%;object-fit:cover}.carousel-admin-info{flex:1;min-width:0}.carousel-admin-info strong{display:block;font-size:.9rem;color:var(--gray-900)}.carousel-admin-info span{font-size:.75rem;color:var(--gray-400)}
