:root{--color-primary: #7c3aed;--color-primary-hover: #6d28d9;--color-primary-light: #ede9fe;--bg-body: #f9fafb;--bg-card: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #111827;--text-secondary: #4b5563;--text-inverse: #ffffff;--border-color: #e5e7eb;--border-focus: #a78bfa;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--header-height: 64px;--container-width: 1280px;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem}:root.dark{--bg-body: #030712;--bg-card: #111827;--text-primary: #f3f4f6;--text-secondary: #9ca3af;--border-color: #1f2937;--color-primary: #8b5cf6;--color-primary-hover: #a78bfa;--color-primary-light: rgba(139, 92, 246, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;position:relative}html{font-size:16px;scroll-behavior:smooth}body{min-height:100vh;color:var(--text-primary);background:var(--bg-body);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:color .3s ease,background-color .3s ease}#app{display:flex;flex-direction:column;min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.25}a{text-decoration:none;color:inherit;transition:color .2s}a:hover{color:var(--color-primary)}button{cursor:pointer;border:none;background:transparent;font-family:inherit}.icon-btn[data-v-78ed50e3]{padding:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn[data-v-78ed50e3]:hover{background-color:var(--bg-body);color:var(--color-primary)}.search-container[data-v-94f4dbd4]{flex:1;max-width:250px;margin:0 1.5rem;display:none}@media(min-width:640px){.search-container[data-v-94f4dbd4]{display:block}}.search-wrapper[data-v-94f4dbd4]{position:relative;display:flex;align-items:center}.search-wrapper .search-icon[data-v-94f4dbd4]{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none;z-index:1;transition:all .3s ease}.search-wrapper .search-icon.searching[data-v-94f4dbd4]{color:var(--color-primary);animation:pulse-94f4dbd4 1s ease-in-out infinite}@keyframes pulse-94f4dbd4{0%,to{opacity:1}50%{opacity:.5}}.search-wrapper .search-input[data-v-94f4dbd4]{width:100%;padding:.6rem 2.5rem;background-color:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:.875rem;color:var(--text-primary);transition:all .2s}.search-wrapper .search-input[data-v-94f4dbd4]:focus{outline:none;border-color:var(--color-primary);background-color:var(--bg-card);box-shadow:0 0 0 3px var(--color-primary-light)}.search-wrapper .clear-search[data-v-94f4dbd4]{position:absolute;right:12px;background:none;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;transition:all .2s}.search-wrapper .clear-search[data-v-94f4dbd4]:hover{background-color:var(--border-color);color:var(--text-primary)}.icon-btn[data-v-53d852e5]{padding:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;position:relative}.icon-btn[data-v-53d852e5]:hover{background-color:var(--bg-body);color:var(--color-primary)}.wishlist-badge[data-v-53d852e5]{position:absolute;top:-2px;right:-2px;background-color:var(--color-primary);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-card);animation:badge-pop-53d852e5 .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes badge-pop-53d852e5{0%{transform:scale(0)}to{transform:scale(1)}}.icon-btn[data-v-9b0b22ae]{padding:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;position:relative}.icon-btn[data-v-9b0b22ae]:hover{background-color:var(--bg-body);color:var(--color-primary)}.cart-btn[data-v-9b0b22ae]{position:relative}.cart-badge[data-v-9b0b22ae]{position:absolute;top:-2px;right:-2px;background-color:var(--color-primary);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-card);animation:badge-pop-9b0b22ae .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes badge-pop-9b0b22ae{0%{transform:scale(0)}to{transform:scale(1)}}.spinner-container[data-v-611f9e73]{display:inline-flex;align-items:center;justify-content:center}.spinner-container .spinner[data-v-611f9e73]{border-style:solid;border-radius:50%;animation:spin-611f9e73 .8s linear infinite}.spinner-container.sm .spinner[data-v-611f9e73]{width:18px;height:18px;border-width:2px}.spinner-container.md .spinner[data-v-611f9e73]{width:32px;height:32px;border-width:3px}.spinner-container.lg .spinner[data-v-611f9e73]{width:50px;height:50px;border-width:4px}.spinner-container.primary .spinner[data-v-611f9e73]{border-color:var(--color-primary-light);border-top-color:var(--color-primary)}.spinner-container.white .spinner[data-v-611f9e73]{border-color:#ffffff4d;border-top-color:#fff}@keyframes spin-611f9e73{to{transform:rotate(360deg)}}.base-button[data-v-2d1fb1eb]{display:inline-flex;align-items:center;justify-content:center;position:relative;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;border:1px solid transparent;white-space:nowrap;-webkit-user-select:none;user-select:none}.base-button.is-block[data-v-2d1fb1eb]{display:flex;width:100%}.base-button[data-v-2d1fb1eb]:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.base-button .button-loader[data-v-2d1fb1eb]{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex}.base-button .button-content[data-v-2d1fb1eb]{display:flex;align-items:center;gap:.5rem}.base-button .opacity-0[data-v-2d1fb1eb]{opacity:0}.base-button.sm[data-v-2d1fb1eb]{padding:.4rem .8rem;font-size:.8125rem}.base-button.md[data-v-2d1fb1eb]{padding:.75rem 1.25rem;font-size:.9375rem}.base-button.lg[data-v-2d1fb1eb]{padding:1rem 2rem;font-size:1.0625rem;border-radius:var(--radius-lg)}.base-button.primary[data-v-2d1fb1eb]{background-color:var(--color-primary);color:#fff}.base-button.primary[data-v-2d1fb1eb]:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.base-button.primary[data-v-2d1fb1eb]:active:not(:disabled){transform:translateY(0)}.base-button.outline[data-v-2d1fb1eb]{background-color:transparent;border-color:var(--border-color);color:var(--text-primary)}.base-button.outline[data-v-2d1fb1eb]:hover:not(:disabled){background-color:var(--bg-body);border-color:var(--color-primary);color:var(--color-primary)}.base-button.ghost[data-v-2d1fb1eb]{background-color:transparent;color:var(--text-secondary)}.base-button.ghost[data-v-2d1fb1eb]:hover:not(:disabled){background-color:var(--bg-body);color:var(--color-primary)}.base-button.danger[data-v-2d1fb1eb]{background-color:transparent;border-color:#fecaca;color:#ef4444}.base-button.danger[data-v-2d1fb1eb]:hover:not(:disabled){background-color:#fef2f2;border-color:#ef4444}.base-button.lg[data-v-2d1fb1eb]{border-radius:var(--radius-lg)}.modal-overlay[data-v-a6a93d3c]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content[data-v-a6a93d3c]{background-color:var(--bg-card);width:100%;max-width:400px;border-radius:var(--radius-xl);padding:2.5rem;position:relative;box-shadow:var(--shadow-xl);border:1px solid var(--border-color)}.close-btn[data-v-a6a93d3c]{position:absolute;top:1rem;right:1rem;width:40px;height:40px;padding:0;border-radius:50%}.modal-header[data-v-a6a93d3c]{text-align:center;margin-bottom:2rem}.modal-title[data-v-a6a93d3c]{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.modal-subtitle[data-v-a6a93d3c]{font-size:.875rem;color:var(--text-secondary)}.login-form[data-v-a6a93d3c]{display:flex;flex-direction:column;gap:1.25rem}.form-group[data-v-a6a93d3c]{display:flex;flex-direction:column;gap:.5rem}.form-group label[data-v-a6a93d3c]{font-size:.875rem;font-weight:600;color:var(--text-primary)}.form-group input[data-v-a6a93d3c]{padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-body);color:var(--text-primary);font-size:.95rem;transition:all .2s}.form-group input[data-v-a6a93d3c]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-group input[data-v-a6a93d3c]:disabled{opacity:.7;cursor:not-allowed}.form-group .hint[data-v-a6a93d3c]{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.form-group .hint span[data-v-a6a93d3c]{font-weight:700;color:var(--color-primary)}.error-message[data-v-a6a93d3c]{padding:.75rem 1rem;background-color:#fef2f2;border:1px solid #fecaca;color:#ef4444;border-radius:var(--radius-md);font-size:.875rem;text-align:center}.modal-footer[data-v-a6a93d3c]{margin-top:2rem;text-align:center;font-size:.875rem;color:var(--text-secondary)}.modal-footer a[data-v-a6a93d3c]{color:var(--color-primary);text-decoration:none;font-weight:600}.modal-footer a[data-v-a6a93d3c]:hover{text-decoration:underline}.modal-fade-enter-active[data-v-a6a93d3c],.modal-fade-leave-active[data-v-a6a93d3c]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-a6a93d3c],.modal-fade-leave-to[data-v-a6a93d3c]{opacity:0}.modal-fade-enter-active .modal-content[data-v-a6a93d3c]{transition:transform .3s ease}.modal-fade-enter-from .modal-content[data-v-a6a93d3c]{transform:scale(.9) translateY(20px)}.auth-section[data-v-c1803166]{display:flex;align-items:center}.user-menu[data-v-c1803166]{display:flex;align-items:center;gap:.75rem}.user-greeting[data-v-c1803166]{display:none;font-size:.875rem;font-weight:600;color:var(--text-primary)}@media(min-width:640px){.user-greeting[data-v-c1803166]{display:block}}.icon-btn[data-v-c1803166]{padding:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer}.icon-btn[data-v-c1803166]:hover{background-color:var(--bg-body);color:var(--color-primary)}.logout-btn[data-v-c1803166]:hover{color:#ef4444;background-color:#fef2f2}.category-nav[data-v-984dc91d]{display:flex;gap:1rem}.category-nav.desktop[data-v-984dc91d]{display:none}@media(min-width:768px){.category-nav.desktop[data-v-984dc91d]{display:flex}}.category-nav.mobile[data-v-984dc91d]{display:flex;flex-direction:column;gap:1rem;width:100%}.category-nav.mobile .nav-link[data-v-984dc91d]{display:block;padding:.75rem 0;border-bottom:1px solid var(--border-color);font-size:1rem}.category-nav.mobile .nav-link[data-v-984dc91d]:last-child{border-bottom:none}.category-nav .nav-link[data-v-984dc91d]{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color .2s}.category-nav .nav-link[data-v-984dc91d]:hover{color:var(--color-primary)}.logo[data-v-229b635a]{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.25rem;color:var(--color-primary);text-decoration:none}.logo[data-v-229b635a]:hover{color:var(--color-primary-hover)}.logo .logo-img[data-v-229b635a]{height:30px;width:auto;display:block}.mobile-menu-overlay[data-v-4c4116cc]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:100;opacity:0;visibility:hidden;transition:all .3s ease}.mobile-menu-overlay.open[data-v-4c4116cc]{opacity:1;visibility:visible}.mobile-menu-overlay.open .mobile-menu-content[data-v-4c4116cc]{transform:translate(0)}.mobile-menu-content[data-v-4c4116cc]{position:absolute;top:0;left:0;width:85%;max-width:320px;height:100%;background-color:var(--bg-card);box-shadow:var(--shadow-xl);transform:translate(-100%);transition:transform .3s ease;display:flex;flex-direction:column}.menu-header[data-v-4c4116cc]{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.menu-header .menu-title[data-v-4c4116cc]{font-size:1.25rem;font-weight:700;margin:0;color:var(--text-primary)}.menu-body[data-v-4c4116cc]{padding:1.5rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:2rem}.search-section[data-v-4c4116cc] .search-container{display:block;max-width:100%;margin:0}.search-section[data-v-4c4116cc] .search-wrapper .search-input{background-color:var(--bg-body)}.nav-section h3[data-v-4c4116cc]{font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);color:var(--text-secondary);margin-bottom:1rem}.hamburger-btn[data-v-5079cd4b]{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;margin-right:.5rem}@media(min-width:768px){.hamburger-btn[data-v-5079cd4b]{display:none}}.app-header[data-v-824dca5c]{height:var(--header-height);background-color:var(--bg-card);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:50;transition:background-color .3s ease,border-color .3s ease}.app-header .container[data-v-824dca5c]{max-width:var(--container-width);margin:0 auto;padding:0 1rem;height:100%;display:flex;align-items:center;justify-content:space-between}.actions[data-v-824dca5c]{display:flex;align-items:center;gap:.75rem}@media(min-width:768px){.actions[data-v-824dca5c]{gap:.5rem}}.main-layout[data-v-8826ed8f]{display:flex;flex-direction:column;min-height:100vh}.main-content[data-v-8826ed8f]{flex:1;width:100%;padding:2rem 0}.container[data-v-8826ed8f]{max-width:var(--container-width);margin:0 auto;padding:0 1rem}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}.product-wishlist-btn[data-v-fbdc520a]{background-color:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.product-wishlist-btn.md[data-v-fbdc520a]{width:52px;height:52px;border-radius:var(--radius-lg)}.product-wishlist-btn.sm[data-v-fbdc520a]{width:34px;height:34px;border-radius:var(--radius-md)}.product-wishlist-btn[data-v-fbdc520a]:hover{color:#ef4444;border-color:#fecaca;background-color:#fef2f2;transform:translateY(-2px)}.product-wishlist-btn.active[data-v-fbdc520a]{color:#ef4444;border-color:#fecaca;background-color:#fef2f2}.category-tag[data-v-79e77e90]{display:inline-block;background-color:var(--color-primary-light);color:var(--color-primary);font-size:.75rem;font-weight:700;padding:.35rem .75rem;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.product-rating[data-v-a03f5c46]{display:flex;align-items:center;gap:.75rem}.product-rating .star[data-v-a03f5c46]{color:var(--color-divider);-webkit-user-select:none;user-select:none}.product-rating .star.active[data-v-a03f5c46]{color:#f59e0b}.product-rating.extended[data-v-a03f5c46]{gap:1rem}.product-rating.extended .stars-visual[data-v-a03f5c46]{display:flex;gap:2px;font-size:1.25rem}.product-rating.extended .rating-text[data-v-a03f5c46]{font-size:.875rem;color:var(--text-secondary);display:flex;gap:.5rem;align-items:center}.product-rating.extended .rating-text .rate-value[data-v-a03f5c46]{font-weight:700;color:var(--text-primary)}.product-rating.short[data-v-a03f5c46]{gap:.25rem;font-size:.85rem}.product-rating.short .rating-compact[data-v-a03f5c46]{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary)}.product-rating.short .rating-compact .star[data-v-a03f5c46]{font-size:1rem}.product-rating.short .rating-compact .rate-value[data-v-a03f5c46]{font-weight:600;color:#f59e0b}.product-rating.short .rating-compact .count-value[data-v-a03f5c46]{opacity:.8}.product-card[data-v-534b579e]{display:flex;flex-direction:column;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;height:100%;text-decoration:none;color:inherit}.product-card[data-v-534b579e]:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border-color:var(--color-primary-light)}.product-card:hover .product-title[data-v-534b579e]{color:var(--color-primary)}.product-image-wrapper[data-v-534b579e]{aspect-ratio:1/1;padding:1.5rem;background-color:#fff;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.product-image[data-v-534b579e]{max-width:100%;max-height:100%;object-fit:contain;transition:transform .5s ease}.product-card:hover .product-image[data-v-534b579e]{transform:scale(1.05)}.category-tag[data-v-534b579e]{position:absolute;top:.75rem;left:.75rem;z-index:1}.wishlist-toggle[data-v-534b579e]{position:absolute;top:.75rem;right:.75rem;z-index:10}.product-info[data-v-534b579e]{padding:1.25rem;display:flex;flex-direction:column;flex:1}.product-title[data-v-534b579e]{font-size:.95rem;font-weight:600;line-height:1.4;margin-bottom:.75rem;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;height:2.8rem;color:var(--text-primary);transition:color .2s ease}.product-footer[data-v-534b579e]{margin-top:auto;display:flex;align-items:center;justify-content:space-between}.product-price[data-v-534b579e]{font-size:1.125rem;font-weight:700;color:var(--color-primary)}.home-page[data-v-bd886e94]{padding-bottom:3rem}.page-header[data-v-bd886e94]{margin-bottom:2.5rem;display:flex;flex-direction:column;gap:1.5rem}@media(min-width:640px){.page-header[data-v-bd886e94]{flex-direction:row;align-items:flex-end;justify-content:space-between}}.header-main[data-v-bd886e94]{display:flex;flex-direction:column;gap:.5rem}.page-title[data-v-bd886e94]{text-transform:capitalize;font-size:2rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.product-count[data-v-bd886e94]{color:var(--text-secondary);font-size:.95rem;font-weight:500}.product-count.loading[data-v-bd886e94]{display:flex;align-items:center;gap:.5rem;color:var(--color-primary)}.controls[data-v-bd886e94]{display:flex;gap:1rem}.sort-wrapper[data-v-bd886e94]{display:flex;align-items:center;gap:.75rem}.sort-wrapper .sort-label[data-v-bd886e94]{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.sort-wrapper .sort-select[data-v-bd886e94]{padding:.5rem 2rem .5rem 1rem;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;transition:all .2s}.sort-wrapper .sort-select[data-v-bd886e94]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.sort-wrapper .sort-select[data-v-bd886e94]:hover{border-color:var(--color-primary)}.pagination[data-v-bd886e94]{margin-top:4rem;display:flex;align-items:center;justify-content:center;gap:1.5rem}.page-numbers[data-v-bd886e94]{display:flex;gap:.5rem}.page-num-btn[data-v-bd886e94]{width:40px;min-width:40px;padding:0}.product-grid[data-v-bd886e94]{display:grid;grid-template-columns:repeat(1,1fr);gap:1.5rem}@media(min-width:640px){.product-grid[data-v-bd886e94]{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.product-grid[data-v-bd886e94]{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.product-grid[data-v-bd886e94]{grid-template-columns:repeat(4,1fr)}}.loading-state[data-v-bd886e94],.error-state[data-v-bd886e94],.empty-state[data-v-bd886e94]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 1rem;text-align:center;gap:1.5rem;background-color:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.error-icon[data-v-bd886e94]{font-size:3rem}
