@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;1,9..40,400&display=swap";:root{--bg:#fff;--bg-alt:#fafafa;--bg-card:#fff;--border:#e5e5e5;--border-strong:#d4d4d4;--text:#171717;--text-muted:#737373;--text-bright:#000;--accent:#000;--accent-hover:#262626;--success:#16a34a;--error:#dc2626;--radius:12px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 1px 3px #0000000f;--shadow:0 4px 12px #00000014;--shadow-lg:0 12px 40px #0000001f;--font-display:"DM Sans", system-ui, sans-serif;--font-body:"DM Sans", system-ui, sans-serif}*{box-sizing:border-box}body{min-height:100vh;font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-stretch:100%}#root{min-height:100vh}a{color:inherit;text-decoration:none;transition:color .2s,opacity .2s}a:hover{opacity:.85}.layout{flex-direction:column;min-height:100vh;display:flex}.main{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:0}.header{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#fffffff2;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;max-width:1280px;margin:0 auto;padding:1rem 2rem;display:flex}.logo{font-family:var(--font-display);letter-spacing:-.04em;color:var(--text-bright);font-size:1.5rem;font-weight:800}.logo:hover{color:var(--accent)}.nav{align-items:center;gap:.5rem;display:flex}.nav-link{color:var(--text-muted);border-radius:var(--radius);align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.nav-link:hover{color:var(--text-bright);background:var(--bg-alt)}.nav-cart{position:relative;background:var(--accent)!important;color:#fff!important}.nav-cart:hover{opacity:1;background:var(--accent-hover)!important;color:#fff!important}.cart-badge{min-width:20px;height:20px;color:var(--accent);border:2px solid var(--accent);background:#fff;border-radius:10px;justify-content:center;align-items:center;padding:0 5px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.footer{border-top:1px solid var(--border);background:var(--bg-alt);margin-top:auto;padding:2rem}.footer-inner{max-width:1280px;color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin:0 auto;font-size:.9rem;display:flex}.footer-logo{font-family:var(--font-display);color:var(--text-bright);font-size:1.1rem;font-weight:800}.footer-nav{gap:1.5rem;display:flex}.footer-nav a{color:var(--text-muted)}.footer-nav a:hover{color:var(--text-bright)}.btn{font-size:.9rem;font-weight:600;font-family:var(--font-body);border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.25rem;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow);transform:translateY(-1px)}.btn-outline{color:var(--text-bright);border:2px solid var(--border-strong);background:0 0}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:var(--bg-alt);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--border);color:var(--text-bright)}.btn-sm{padding:.45rem .9rem;font-size:.85rem}.btn-lg{padding:.85rem 1.75rem;font-size:1rem}.btn-block{width:100%}.home{padding-bottom:4rem}.hero{text-align:center;padding:5rem 2rem 6rem;position:relative;overflow:hidden}.hero-bg{background:radial-gradient(ellipse 80% 50% at 50% 0%, #00000008 0%, transparent 50%), linear-gradient(180deg, var(--bg-alt) 0%, var(--bg) 100%);pointer-events:none;position:absolute;inset:0}.hero-content{max-width:720px;margin:0 auto;position:relative}.hero-label{letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem;font-size:.8rem;font-weight:600;display:inline-block}.hero h1{font-family:var(--font-display);letter-spacing:-.04em;color:var(--text-bright);margin:0 0 1.5rem;font-size:clamp(2.5rem,6vw,4rem);font-weight:800;line-height:1.1}.hero-desc{color:var(--text-muted);margin:0 0 2rem;font-size:1.2rem;line-height:1.6}.hero-actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.features{background:var(--bg-alt);padding:4rem 2rem}.features-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem;max-width:1000px;margin:0 auto;display:grid}.feature-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:all .2s}.feature-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.feature-icon{background:var(--bg-alt);border-radius:var(--radius);width:48px;height:48px;color:var(--accent);justify-content:center;align-items:center;margin-bottom:1.25rem;display:flex}.feature-card h3{font-family:var(--font-display);color:var(--text-bright);margin:0 0 .5rem;font-size:1.2rem;font-weight:700}.feature-card p{color:var(--text-muted);margin:0;font-size:.95rem;line-height:1.5}.about-preview{padding:4rem 2rem}.about-preview-inner{text-align:center;max-width:640px;margin:0 auto}.about-preview h2{font-family:var(--font-display);color:var(--text-bright);margin:0 0 1rem;font-size:1.75rem;font-weight:700}.about-preview p{color:var(--text-muted);margin:0 0 1rem;font-size:1.05rem;line-height:1.7}.link-arrow{color:var(--accent);align-items:center;gap:.5rem;margin-top:1rem;font-weight:600;display:inline-flex}.link-arrow:hover{opacity:.8}.featured{background:var(--bg-alt);padding:4rem 2rem}.featured-header{justify-content:space-between;align-items:center;max-width:1280px;margin-bottom:2rem;margin-left:auto;margin-right:auto;display:flex}.featured h2{font-family:var(--font-display);color:var(--text-bright);margin:0;font-size:1.75rem;font-weight:700}.view-all{color:var(--accent);font-weight:600}.view-all:hover{text-decoration:underline}.featured-grid{max-width:1280px;margin:0 auto}.product-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.product-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .2s;overflow:hidden}.product-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.product-card-image{aspect-ratio:4/3;background:var(--bg-alt);display:block;position:relative;overflow:hidden}.product-card-image img{object-fit:cover;width:100%;height:100%}.product-placeholder{background:linear-gradient(135deg, var(--bg-alt) 0%, var(--border) 100%);width:100%;height:100%;color:var(--text-muted);font-family:var(--font-display);justify-content:center;align-items:center;font-size:1.5rem;font-weight:800;display:flex}.product-placeholder.large{aspect-ratio:4/3;font-size:3rem}.product-badge{background:var(--success);color:#fff;border-radius:6px;padding:.25rem .6rem;font-size:.75rem;font-weight:700;position:absolute;top:.75rem;right:.75rem}.product-card-body{padding:1.25rem}.product-card-name{font-family:var(--font-display);color:var(--text-bright);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 .5rem;font-size:1.05rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.product-card-price{color:var(--accent);margin:0 0 1rem;font-size:1.1rem;font-weight:700}.product-card-actions{gap:.5rem;display:flex}.product-card-actions .btn{flex:1}.product-page{padding:2rem}.back-link{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;display:inline-flex}.back-link:hover{color:var(--text-bright)}.product-detail{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;margin-bottom:3rem;display:grid}.product-gallery{position:sticky;top:100px}.gallery-main{aspect-ratio:4/3;background:var(--bg-alt);border-radius:var(--radius-lg);margin-bottom:1rem;overflow:hidden}.gallery-main img{object-fit:cover;width:100%;height:100%}.gallery-thumbs{gap:.5rem;display:flex}.gallery-thumb{border-radius:var(--radius);cursor:pointer;background:var(--bg-alt);border:2px solid #0000;width:64px;height:48px;padding:0;transition:border-color .2s;overflow:hidden}.gallery-thumb:hover,.gallery-thumb.active{border-color:var(--accent)}.gallery-thumb img{object-fit:cover;width:100%;height:100%}.product-detail-info{padding:0}.product-category-tag{color:var(--accent);margin-bottom:.75rem;font-size:.8rem;font-weight:600;display:inline-block}.product-detail-info h1{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text-bright);margin:0 0 .75rem;font-size:2rem;font-weight:800}.product-detail-price-row{align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.product-detail-price{color:var(--accent);font-size:2rem;font-weight:800}.product-detail-badge{background:var(--success);color:#fff;border-radius:6px;padding:.25rem .6rem;font-size:.8rem;font-weight:600}.product-description{color:var(--text);margin:1.5rem 0;font-size:1rem;line-height:1.7}.product-description p{margin:.5rem 0}.related-products{border-top:1px solid var(--border);padding-top:2rem}.related-products h2{font-family:var(--font-display);color:var(--text-bright);margin:0 0 1.5rem;font-size:1.5rem;font-weight:700}.product-not-found{text-align:center;padding:4rem 2rem}.product-not-found h2{font-family:var(--font-display);margin-bottom:.5rem}.product-not-found p{color:var(--text-muted);margin-bottom:1.5rem}.store-layout{padding:2rem}.store-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.search-bar{flex:1;min-width:200px;max-width:400px;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-bright);padding:.65rem 1rem .65rem 2.75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.search-input:focus{border-color:var(--accent);outline:none}.sort-select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;padding:.65rem 1rem;font-family:inherit;font-size:.9rem}.breadcrumbs{color:var(--text-muted);margin-bottom:1.5rem;font-size:.85rem}.breadcrumb a{color:var(--text-muted)}.breadcrumb a:hover{color:var(--text-bright)}.breadcrumb-sep{opacity:.5;margin:0 .5rem}.store-body{align-items:flex-start;gap:2rem;display:flex}.store-sidebar{flex-shrink:0;width:240px}.sidebar-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1.25rem}.sidebar-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .75rem;font-size:.75rem;font-weight:600}.sidebar-link{color:var(--text);border-radius:6px;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.9rem;transition:all .15s;display:flex}.sidebar-link:hover{color:var(--text-bright);background:var(--bg-alt)}.sidebar-link.active{color:var(--accent);font-weight:600}.sidebar-count{color:var(--text-muted);font-size:.8rem}.store-main{flex:1;min-width:0}.store-content{width:100%}.store-header{margin-bottom:1.5rem}.store-header h1{font-family:var(--font-display);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.store-subtitle{color:var(--text-muted);margin:0;font-size:.9rem}.empty-store{text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:3rem}.page-about{padding:4rem 2rem}.page-about-inner{max-width:640px;margin:0 auto}.page-about-inner h1{font-family:var(--font-display);letter-spacing:-.03em;margin:0 0 .5rem;font-size:2.5rem;font-weight:800}.page-tagline{color:var(--text-muted);margin:0 0 1.5rem;font-size:1.1rem}.about-content{line-height:1.75}.about-content h2{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:2rem 0 .5rem;font-size:1rem;font-weight:600}.about-content ul{margin:.5rem 0 1rem;padding-left:1.5rem}.cart-items .glass-panel,.page-about .glass-panel{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.cart-item{border-bottom:1px solid var(--border);padding:1rem 0}.cart-item:last-child{border-bottom:none}.cart-footer{padding:1.5rem 0}.cart-total{margin-bottom:1rem;font-size:1.25rem;font-weight:700}.cart-actions{flex-wrap:wrap;gap:.75rem;display:flex}.page-loading,.page-error{text-align:center;padding:4rem 2rem}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 2rem}.empty-state .btn{margin-top:1rem}.cart-loading{text-align:center;padding:2rem}.thank-you-page{justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.thank-you-card{text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:420px;padding:3rem}.thank-you-icon{background:var(--success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.5rem;display:flex}.thank-you-card h1{font-family:var(--font-display);margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.thank-you-card p{color:var(--text-muted);margin:0 0 1.5rem;line-height:1.5}.recent-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.7rem;font-weight:700;display:flex}.recent-item{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding:.5rem 0;font-size:.85rem;display:flex}.recent-item:last-child{border-bottom:none}.recent-info{flex-direction:column;flex:1;min-width:0;display:flex}.recent-user{color:var(--text-bright);font-weight:600}.recent-product{color:var(--text-muted);font-size:.8rem}.recent-price{color:var(--success);font-weight:600}@media (width<=900px){.product-detail{grid-template-columns:1fr}.product-gallery{position:static}.store-body{flex-direction:column}.store-sidebar{width:100%}}@media (width<=768px){.header-inner{padding:1rem}.nav-link .nav-text{display:none}.nav-link{padding:.5rem}.hero{padding:3rem 1rem 4rem}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}.features,.about-preview,.featured{padding:2rem 1rem}.product-page{padding:1rem}}
