@import url("https://fonts.googleapis.com/css2?family=Fredoka:wght@400;600;700&display=swap");.products-page{font-family:Fredoka,sans-serif;min-height:100vh;background:linear-gradient(180deg,rgba(249,250,251,.5),white)}.products-hero{background:linear-gradient(135deg,#4f46e5,#22c55e);padding:120px 20px 80px;position:relative;overflow:hidden}.products-hero:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="40" fill="rgba(255,255,255,0.05)"/></svg>');background-size:200px 200px;opacity:.3}.products-hero-content{max-width:1400px;margin:0 auto;text-align:center;position:relative;z-index:1}.products-hero-title{font-size:3.5rem;font-weight:700;color:white;margin:0 0 16px;text-shadow:0 4px 12px rgba(0,0,0,.2)}.products-hero-subtitle{font-size:1.3rem;color:rgba(255,255,255,.95);margin:0 0 40px}.products-hero-stats{display:flex;justify-content:center;gap:60px}.hero-stat{display:flex;flex-direction:column;align-items:center}.stat-number{font-size:2.5rem;font-weight:700;color:white;line-height:1}.stat-label{font-size:.9rem;color:rgba(255,255,255,.8);margin-top:8px;text-transform:uppercase;letter-spacing:.5px}.products-container{max-width:1400px;margin:0 auto;padding:40px 20px;display:grid;grid-template-columns:280px 1fr;grid-gap:40px;gap:40px;align-items:start}.products-sidebar{position:-webkit-sticky;position:sticky;top:140px;background:white;border-radius:20px;padding:24px;border:1px solid rgba(0,0,0,.06);box-shadow:0 4px 16px rgba(0,0,0,.06)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid rgba(0,0,0,.06)}.sidebar-header h2{font-size:1.4rem;font-weight:700;color:#111827;margin:0}.clear-filters{background:none;border:none;color:#4f46e5;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .3s ease;text-decoration:underline}.clear-filters:hover{color:#22c55e}.filter-group{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,.06)}.filter-group:last-of-type{border-bottom:none}.filter-title{font-size:1.05rem;font-weight:700;color:#111827;margin:0 0 12px}.filter-options{display:flex;flex-direction:column;gap:8px}.filter-option{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer;transition:background .2s ease}.filter-option:hover{background:rgba(79,70,229,.05)}.filter-option input[type=radio]{width:18px;height:18px;accent-color:#4f46e5;cursor:pointer}.filter-label{flex:1 1;font-size:.95rem;color:#374151;font-weight:500}.filter-count{font-size:.85rem;color:#9ca3af}.price-range-display{padding:12px;background:linear-gradient(135deg,rgba(79,70,229,.1),rgba(34,197,94,.1));border-radius:8px;text-align:center;font-weight:700;color:#4f46e5;margin-bottom:16px;font-size:1.05rem}.price-slider-container{position:relative;height:40px;margin-top:8px}.price-slider-track{position:absolute;top:50%;transform:translateY(-50%);left:0;right:0;height:6px;background:#e2e8f0;border-radius:3px}.price-slider-range{position:absolute;height:100%;background:linear-gradient(90deg,#4f46e5,#22c55e);border-radius:3px}.price-slider{position:absolute;width:100%;height:6px;background:transparent;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;pointer-events:none;top:50%;transform:translateY(-50%)}.price-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:white;border:3px solid #4f46e5;cursor:pointer;box-shadow:0 2px 8px rgba(79,70,229,.3);pointer-events:auto;position:relative;z-index:2}.price-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:white;border:3px solid #4f46e5;cursor:pointer;box-shadow:0 2px 8px rgba(79,70,229,.3);pointer-events:auto;position:relative;z-index:2}.price-slider-max::-webkit-slider-thumb{border-color:#22c55e}.price-slider-max::-moz-range-thumb{border-color:#22c55e}.sidebar-promo{margin-top:24px;padding:20px;background:linear-gradient(135deg,#4f46e5,#22c55e);border-radius:16px;text-align:center;color:white}.promo-icon{font-size:2rem;margin-bottom:8px}.sidebar-promo h4{font-size:1.1rem;font-weight:700;margin:0 0 8px}.sidebar-promo p{font-size:.9rem;margin:0 0 12px;opacity:.95}.promo-code{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);border-radius:8px;font-family:monospace;font-weight:700;font-size:1rem;letter-spacing:1px;transition:all .3s ease}.promo-code.clickable{cursor:pointer}.promo-code.clickable:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.5);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.promo-code.clickable:active{transform:translateY(0)}.promo-code svg{flex-shrink:0}.search-wrapper{position:relative;display:flex;align-items:center;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb;padding:0 12px;transition:all .3s ease;min-width:300px;margin-right:20px}.search-wrapper:focus-within{border-color:#4f46e5;background:white;box-shadow:0 0 0 3px rgba(79,70,229,.1)}.search-icon{color:#9ca3af;margin-right:8px;flex-shrink:0}.search-input{flex:1 1;border:none;background:transparent;padding:10px 0;font-size:.95rem;color:#1f2937;font-family:Fredoka,sans-serif;outline:none;min-width:0}.search-input::placeholder{color:#9ca3af}.search-clear{background:transparent;border:none;color:#9ca3af;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;margin-left:4px}.search-clear:hover{background:#e5e7eb;color:#1f2937}.products-toolbar{justify-content:space-between;padding:20px 24px;background:white;border-radius:16px;margin-bottom:32px;border:1px solid rgba(0,0,0,.06);box-shadow:0 2px 8px rgba(0,0,0,.04)}.products-toolbar,.toolbar-left{display:flex;align-items:center}.results-count{font-size:.95rem;color:#6b7280;margin:0;white-space:nowrap}.results-count strong{color:#111827;font-weight:700}.toolbar-right{display:flex;align-items:center;gap:16px}.sort-label{color:#6b7280;margin-right:8px}.sort-label,.sort-select{font-size:.95rem;font-weight:600}.sort-select{padding:10px 16px;border:2px solid rgba(0,0,0,.1);border-radius:10px;font-family:inherit;color:#111827;background:white;cursor:pointer;transition:all .3s ease}.sort-select:focus,.sort-select:hover{border-color:#4f46e5}.sort-select:focus{outline:none;box-shadow:0 0 0 3px rgba(79,70,229,.1)}.products-loading{display:flex;justify-content:center;align-items:center;min-height:400px;padding:60px 20px}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:24px}.spinning-can{width:120px;height:auto;animation:spin 1.5s linear infinite;filter:drop-shadow(0 8px 24px rgba(79,70,229,.2))}.loading-text{font-size:1.2rem;font-weight:600;color:#4f46e5;margin:0;animation:pulse 2s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:32px;gap:32px}.product-count-footer{text-align:center;padding:32px 20px;margin-top:24px;border-top:2px solid #e5e7eb}.product-count-footer p{font-size:1rem;color:#6b7280;margin:0}.product-count-footer strong{color:#111827;font-weight:700}.product-card{position:relative;background:white;border-radius:20px;overflow:hidden;border:1px solid rgba(0,0,0,.06);box-shadow:0 4px 16px rgba(0,0,0,.06);transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;flex-direction:column}.product-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px rgba(79,70,229,.15)}.product-badges{position:absolute;top:16px;left:16px;z-index:10;display:flex;flex-direction:column;gap:8px}.badge-strong,.badge-top{padding:6px 12px;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.badge-top{background:linear-gradient(135deg,rgba(251,191,36,.95),rgba(245,158,11,.95));color:white}.badge-strong{background:linear-gradient(135deg,rgba(239,68,68,.95),rgba(220,38,38,.95));color:white}.product-image-link{display:block;padding:40px 20px 20px;background:linear-gradient(180deg,rgba(249,250,251,.5),rgba(255,255,255,0));cursor:pointer;text-decoration:none}.product-image{width:100%;height:200px;object-fit:contain;transition:transform .5s cubic-bezier(.175,.885,.32,1.275);filter:drop-shadow(0 4px 12px rgba(0,0,0,.08))}.product-card:hover .product-image{transform:scale(1.1) rotate(-5deg)}.product-info{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1 1}.product-brand{font-size:.8rem;font-weight:700;color:#4f46e5;text-transform:uppercase;letter-spacing:.5px}.product-name-link{text-decoration:none;cursor:pointer;display:block}.product-name{font-size:1.2rem;font-weight:700;color:#111827;margin:0;transition:color .3s ease;line-height:1.4}.product-card:hover .product-name,.product-name-link:hover .product-name{color:#4f46e5}.product-nicotine{font-size:1.25rem;font-weight:500;color:#6b7280;margin:6px 0 12px}.product-rating{display:flex;align-items:center;gap:6px}.stars{display:flex;gap:2px}.star{color:#d1d5db}.star.filled{color:#fbbf24;filter:drop-shadow(0 1px 2px rgba(251,191,36,.4))}.rating-text{font-size:.9rem;font-weight:600;color:#6b7280;margin-left:2px}.rating-count{font-size:.85rem;color:#9ca3af}.product-meta{display:flex;gap:8px}.product-flavor,.product-strength{padding:4px 10px;background:linear-gradient(135deg,rgba(79,70,229,.1),rgba(34,197,94,.1));border-radius:6px;font-weight:700;font-size:.8rem;color:#4f46e5}.product-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid rgba(0,0,0,.06)}.product-price-wrapper{display:flex;flex-direction:column;gap:2px}.product-price{font-size:1.6rem;font-weight:800;color:#111827;line-height:1;background:linear-gradient(135deg,#4f46e5,#22c55e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.price-label{font-size:.75rem;color:#9ca3af;font-weight:500}.add-to-cart-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:linear-gradient(135deg,#4f46e5,#22c55e);color:white;border:none;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px rgba(79,70,229,.3);font-family:inherit}.add-to-cart-btn:hover{transform:scale(1.05);box-shadow:0 6px 20px rgba(79,70,229,.4)}.add-to-cart-btn:active{transform:scale(.98)}.no-results{grid-column:1/-1;text-align:center;padding:80px 20px}.no-results svg{color:#d1d5db;margin-bottom:24px}.no-results h3{font-size:1.8rem;font-weight:700;color:#111827;margin:0 0 12px}.no-results p{font-size:1.05rem;color:#6b7280;margin:0 0 32px}.btn2{font-family:inherit;cursor:pointer;transition:all .25s ease;border:1px solid black;padding:12px 30px;background-color:black;color:white;border-radius:10px;box-shadow:4px 4px 0 rgba(105,105,105,.1);text-decoration:none;font-size:1rem;font-weight:600}.btn2.accent{border:0;background:linear-gradient(135deg,#4f46e5,#22c55e 60%,#06b6d4);color:white;box-shadow:0 10px 20px rgba(79,70,229,.25)}.btn2.accent:hover{box-shadow:0 14px 28px rgba(79,70,229,.35);transform:translateY(-3px) scale(1.02)}@media (max-width:1200px){.products-container{grid-template-columns:260px 1fr;gap:30px}}@media (max-width:1024px){.products-container{grid-template-columns:1fr}.products-sidebar{position:static;margin-bottom:32px}.products-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width:768px){.products-hero{padding:100px 20px 60px}.products-hero-title{font-size:2.5rem}.products-hero-subtitle{font-size:1.1rem}.products-hero-stats{flex-direction:column;gap:24px}.products-toolbar{gap:16px}.products-toolbar,.toolbar-left{flex-direction:column;align-items:stretch}.toolbar-left{gap:12px}.search-wrapper{min-width:auto;margin-right:0}.search-input{font-size:.95rem}.search-input::placeholder{font-size:.9rem}.results-count{text-align:center}.toolbar-right{justify-content:space-between}.products-grid{grid-template-columns:1fr;gap:24px}.stat-number{font-size:2rem}}@media (max-width:480px){.products-hero-title{font-size:2rem}.sidebar-header h2{font-size:1.2rem}.filter-title{font-size:.95rem}.product-price{font-size:1.4rem}}