.products-fixed-header{position:fixed;top:0;left:0;right:0;z-index:20;background:linear-gradient(to bottom,#fff 0%,#fff 85%,transparent 100%);padding:0 24px 16px}.products-fixed-header .mobile-header{margin:0 -24px}.products-fixed-header .filter-chips{margin:0;padding-left:0;padding-right:0}.products-search{position:relative;margin-bottom:16px}.products-search-input{width:100%;height:48px;padding:0 16px 0 48px;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:16px;font-size:15px;color:#1e293b;transition:border-color .15s ease,box-shadow .15s ease}.products-search-input:focus{outline:none;border-color:var(--unprint-blue, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.products-search-input::placeholder{color:#94a3b8}.products-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#94a3b8;pointer-events:none}.products-search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:#e2e8f0;display:none;align-items:center;justify-content:center;cursor:pointer;color:#64748b}.products-search-clear.visible{display:flex}.products-search-clear svg{width:14px;height:14px}.filter-chips{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;margin:0 -24px 16px;padding-left:24px;padding-right:24px;-webkit-overflow-scrolling:touch}.filter-chips::-webkit-scrollbar{display:none}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:999px;font-size:13px;font-weight:600;color:#475569;white-space:nowrap;cursor:pointer;transition:all .15s ease}.filter-chip:active{transform:scale(.97)}.filter-chip.active{background:#0f172a;border-color:#0f172a;color:#fff}.filter-chip-icon{width:18px;height:18px;border-radius:6px;display:flex;align-items:center;justify-content:center}.filter-chip.active .filter-chip-icon{background:#fff3}.filter-chip-icon svg{width:12px;height:12px}.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.products-grid-item{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:16px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column;gap:12px}.products-grid-item:active{transform:scale(.97)}.products-grid-item-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.products-grid-item-icon svg{width:24px;height:24px;color:#fff}.products-grid-item-name{font-size:14px;font-weight:700;color:#1e293b;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.products-grid-item-desc{font-size:12px;color:#64748b;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.products-grid-item-badge{display:inline-flex;align-items:center;padding:3px 8px;background:var(--unprint-mint, #00ff94);color:#0a0a0a;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;width:fit-content}.products-grid-item-badge.new{background:#3b82f6;color:#fff}.specialty-section{margin-top:24px;padding-top:24px;border-top:1px solid rgba(0,0,0,.06)}.specialty-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.specialty-section-title{font-size:15px;font-weight:700;color:#1e293b}.specialty-section-note{font-size:11px;color:#94a3b8}.specialty-list{display:flex;flex-direction:column;gap:10px}.specialty-item{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:14px 16px;cursor:pointer;transition:transform .15s ease}.specialty-item:active{transform:scale(.98)}.specialty-item-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.specialty-item-icon svg{width:22px;height:22px;color:#fff}.specialty-item-content{flex:1;min-width:0}.specialty-item-name{font-size:14px;font-weight:700;color:#1e293b;margin-bottom:2px}.specialty-item-desc{font-size:12px;color:#64748b;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.specialty-item-arrow{width:20px;height:20px;color:#cbd5e1;flex-shrink:0}.products-empty{text-align:center;padding:40px 20px}.products-empty-icon{width:64px;height:64px;margin:0 auto 16px;background:#f1f5f9;border-radius:50%;display:flex;align-items:center;justify-content:center}.products-empty-icon svg{width:32px;height:32px;color:#94a3b8}.products-empty-title{font-size:16px;font-weight:700;color:#1e293b;margin-bottom:6px}.products-empty-text{font-size:13px;color:#64748b}.product-sheet-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.product-sheet-icon svg{width:28px;height:28px;color:#fff}.product-sheet-name{font-size:18px;font-weight:700;color:#1e293b;margin-bottom:8px}.product-sheet-desc{font-size:14px;color:#64748b;line-height:1.5;margin-bottom:16px}.product-sheet-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.product-sheet-tag{display:inline-flex;align-items:center;padding:6px 12px;background:#f1f5f9;border-radius:999px;font-size:12px;font-weight:500;color:#475569}.products-loading{display:flex;flex-direction:column;gap:14px}.products-loading-item{height:100px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:18px;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.template-detail{max-width:600px;margin:0 auto}.template-hero{width:100%;aspect-ratio:3 / 4;max-height:400px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.hero-image{width:100%;height:100%;object-fit:contain}.hero-placeholder{display:flex;align-items:center;justify-content:center;color:#cbd5e1}.hero-placeholder svg{width:64px;height:64px}.template-info{padding:0 16px}.template-name{font-size:22px;font-weight:700;color:#1e293b;margin-bottom:8px;line-height:1.3}.template-artist{display:flex;align-items:center;gap:6px;font-size:14px;color:#64748b;margin-bottom:12px}.artist-label{color:#94a3b8}.artist-name{color:#3b82f6;text-decoration:none;font-weight:500}.artist-name:hover{text-decoration:underline}.template-description{font-size:14px;color:#64748b;line-height:1.6;margin-bottom:16px}.template-meta{display:flex;gap:24px;padding:16px 0;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;margin-bottom:16px}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}.meta-value{font-size:14px;font-weight:600;color:#1e293b}.template-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.template-tag{padding:6px 12px;background:#f1f5f9;border-radius:999px;font-size:12px;font-weight:500;color:#475569}.template-actions{position:fixed;bottom:80px;left:0;right:0;padding:16px 20px;background:#fff;border-top:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;gap:16px;z-index:10}.price-display{font-size:24px;font-weight:800;color:#1e293b}.btn-primary.btn-lg{flex:1;padding:14px 24px;font-size:15px;font-weight:600;text-align:center;background:#0f172a;color:#fff;border-radius:12px;text-decoration:none}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.error-state h2{font-size:18px;font-weight:600;color:#1e293b;margin:16px 0 8px}.error-state p{font-size:14px;color:#64748b;margin-bottom:24px}.error-icon svg{width:48px;height:48px;color:#cbd5e1}@media(min-width:768px){.template-detail{padding:24px}.template-hero{max-height:500px;border-radius:20px}.template-name{font-size:28px}.template-actions{position:static;background:transparent;border:none;padding:24px 0;max-width:400px}}
