*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;width:100%;height:100%}body{width:100%;font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:#f0f0f0;overflow-x:hidden;min-height:100vh}body,html{overflow-x:hidden}:root{--primary:#8B0000;--dark:#660000;--accent:#DC143C;--success:#16a34a;--warning:#f59e0b;--error:#ef4444}.header{background:linear-gradient(135deg,#c0392b 0,#e05c5c 50%,#c0392b 100%);color:#fff;padding:10px 16px;position:fixed;top:0;left:0;right:0;z-index:101;box-shadow:0 4px 20px rgba(139,0,0,.25);border-bottom:1px solid rgba(255,255,255,.1);transition:transform .5s cubic-bezier(.4,0,.2,1),box-shadow .5s ease}.header.hide{transform:translateY(-100%);box-shadow:none}.header-flex{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:20px}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px}.header-user{display:flex;align-items:center;gap:10px}.header-btn{background:rgba(255,255,255,.2);color:#fff;border:1.5px solid rgba(255,255,255,.35);padding:8px 18px;border-radius:6px;cursor:pointer;font-weight:700;transition:all .3s ease;font-size:13px}.header-btn:hover{background:rgba(255,255,255,.3);transform:translateY(-2px)}.logout-icon-btn{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.3);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:0}.logout-icon-btn:hover{border-color:rgba(255,255,255,.6);transform:translateY(-2px) rotate(-5deg)}#stickySearch{position:fixed;left:0;right:0;z-index:100;background:#f0f0f0;padding:14px 16px 12px;box-shadow:0 2px 8px rgba(0,0,0,.06);top:60px;transition:top .5s cubic-bezier(.4,0,.2,1),box-shadow .5s ease}#searchInput::placeholder{color:#94a3b8;font-weight:500;transition:opacity .3s}#searchInput:focus::placeholder{opacity:0}.nav{position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.97);border-top:1px solid #e2e8f0;display:flex;justify-content:space-around;z-index:150;box-shadow:0 -6px 24px rgba(0,0,0,.08);backdrop-filter:blur(10px);padding:6px 0}.nav-btn{flex:1;padding:10px 6px;text-align:center;cursor:pointer;color:#c0392b;border:none;background:0 0;font-size:10px;font-weight:700;transition:all .3s ease;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.nav-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;color:currentColor}.nav-btn.active{color:var(--primary);opacity:1}.nav-btn.active .nav-icon{animation:navBounce .5s ease}.nav-btn.active::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:28px;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:3px}@keyframes navBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}.btn{width:100%;padding:14px;background:linear-gradient(135deg,#8b0000 0,#dc143c 100%);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;margin-top:10px;transition:all .3s ease;font-size:15px}.btn:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(139,0,0,.3)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.price-add-row{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.add-btn{background:#fff;color:#2e7d32;border:1.5px solid #2e7d32;border-radius:8px;padding:5px 14px;font-weight:700;cursor:pointer;font-size:13px;transition:all .2s ease;white-space:nowrap}.add-btn:hover{background:#f1f8e9}.add-btn:disabled{background:#f5f5f5;color:#999;border-color:#ccc;cursor:not-allowed}.add-btn.added{background:#2e7d32;color:#fff;border-color:#2e7d32}.auth{display:none;align-items:center;justify-content:center;position:fixed;inset:0;background:rgba(0,0,0,.6);padding:20px;z-index:9999;backdrop-filter:blur(5px)}.auth.show{display:flex;animation:fadeIn .3s ease}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.auth-box{background:#fff;padding:36px;border-radius:20px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 48px rgba(0,0,0,.2);position:relative;animation:slideUp .3s ease}.auth-close{position:absolute;top:16px;right:20px;background:0 0;border:none;font-size:24px;cursor:pointer;color:#94a3b8;transition:all .3s}.auth-close:hover{color:var(--primary);transform:rotate(90deg)}.auth-title{font-size:26px;font-weight:800;text-align:center;margin-bottom:6px;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{text-align:center;color:#94a3b8;margin-bottom:22px;font-weight:500;font-size:14px}.auth-tabs{display:flex;gap:10px;margin-bottom:22px;border-bottom:2px solid #e2e8f0}.auth-tab{flex:1;padding:12px;background:0 0;border:none;cursor:pointer;font-weight:700;color:#94a3b8;border-bottom:3px solid transparent;transition:all .3s}.auth-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.form{display:none}.form.active{display:block;animation:fadeIn .3s ease}.form-group{margin-bottom:14px}.form-group label{display:block;margin-bottom:6px;font-weight:700;font-size:13px;color:#334155}.form-group input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:14px;transition:all .3s;font-weight:500}.form-group input:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 4px rgba(139,0,0,.08)}.error{color:var(--error);font-size:13px;margin-top:8px;padding:10px;background:rgba(239,68,68,.08);border-radius:8px;display:none;border-left:3px solid var(--error)}.error.show{display:block;animation:fadeIn .3s ease}.success{color:var(--success);font-size:13px;margin-top:8px;padding:10px;background:rgba(22,163,74,.08);border-radius:8px;display:none;border-left:3px solid var(--success)}.success.show{display:block;animation:fadeIn .3s ease}.content{max-width:1200px;margin:0 auto;padding:20px;padding-bottom:100px;padding-top:140px}@media (max-width:768px){.content{padding:10px;padding-bottom:100px;padding-top:130px}}.coupon-section{background:linear-gradient(135deg,#f59e0b 0,#f97316 100%);border-radius:16px;padding:22px;margin:24px 0;color:#fff;box-shadow:0 8px 24px rgba(245,158,11,.25)}.coupon-title{font-size:18px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:8px}.coupon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.coupon-card{background:rgba(255,255,255,.15);border:2px dashed rgba(255,255,255,.4);border-radius:12px;padding:14px;cursor:pointer;transition:all .3s ease;text-align:center}.coupon-card:hover{background:rgba(255,255,255,.25);transform:translateY(-3px)}.coupon-code{font-weight:900;font-size:14px;letter-spacing:1px;margin-bottom:5px}.coupon-desc{font-size:11px;opacity:.9;font-weight:600}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:24px}.product-grid{display:grid;grid-template-columns:repeat(2,1fr)!important;gap:10px;margin-bottom:24px}@media (min-width:769px){.grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.product-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))!important;gap:16px}}.card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;transition:all .3s ease;position:relative;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.04)}.card:hover{box-shadow:0 16px 32px rgba(0,0,0,.08);transform:translateY(-6px)}.offer-ribbon{position:absolute;top:10px;left:0;background:#e53935;color:#fff;font-size:10px;font-weight:800;padding:4px 10px 4px 8px;border-radius:0 20px 20px 0;z-index:10;letter-spacing:.04em;box-shadow:2px 2px 6px rgba(229,57,53,.3)}.like-badge{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.95);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;width:32px;height:32px;border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.06);padding:0;transition:all .3s ease}.like-badge:hover{transform:scale(1.15)}.product-img{width:100%;height:200px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:8px}.product-img img{width:100%;height:100%;object-fit:contain;border-radius:10px}.product-info{padding:16px}.product-name{font-weight:500;font-size:14px;margin-bottom:7px;color:#1a1a2e;line-height:1.35;min-height:36px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;letter-spacing:0;font-family:"Nunito","Segoe UI",sans-serif}@media (max-width:480px){.product-img{height:140px;padding:6px}.product-info{padding:8px}.product-name{font-size:12px;margin-bottom:5px;min-height:30px;font-weight:500}.product-price{font-size:12px!important}.product-original-price{font-size:10px!important}.product-offer-badge{font-size:9px!important;padding:1px 4px}.add-btn{font-size:13px;padding:5px 10px}.price-add-row{gap:4px}.product-price-row{gap:3px}}.product-price-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:7px}.product-price{color:#1e293b;font-weight:800;font-size:15px}.product-original-price{color:#94a3b8;font-size:11px;text-decoration:line-through}.product-offer-badge{display:inline-block;background:rgba(22,163,74,.1);color:var(--success);font-size:10px;font-weight:800;padding:2px 6px;border-radius:6px}.detail-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:8000;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}@media (min-width:600px){.detail-modal{align-items:center}}.detail-modal.show{display:flex;animation:fadeIn .22s ease}.detail-modal-box{background:#fff;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;overscroll-behavior:contain;border-radius:22px 22px 0 0;position:relative;animation:slideUpSheet .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -6px 32px rgba(0,0,0,.18);scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.detail-modal-box::-webkit-scrollbar{width:4px}.detail-modal-box::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:2px}@media (min-width:600px){.detail-modal-box{border-radius:20px;animation:slideUp .26s ease;margin:16px}}@keyframes slideUpSheet{from{transform:translateY(100%)}to{transform:translateY(0)}}.detail-drag-handle{width:36px;height:4px;background:#d1d5db;border-radius:2px;margin:12px auto 0}@media (min-width:600px){.detail-drag-handle{display:none}}.detail-close{position:absolute;top:14px;right:16px;background:rgba(0,0,0,.07);border:none;cursor:pointer;color:#64748b;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .22s;font-size:16px;z-index:10;font-weight:800}.detail-close:hover{background:var(--primary);color:#fff}.detail-img{width:100%;height:200px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:10px;position:relative}.detail-img img{width:100%;height:100%;object-fit:contain;border-radius:14px}.detail-content{padding:12px 16px 20px}.detail-top-row{display:flex;align-items:center;justify-content:flex-end;margin-bottom:6px}.detail-category-badge{display:none}.detail-category-ribbon{position:absolute;top:18px;left:-6px;background:linear-gradient(135deg,#c0392b,#e05c5c);color:#fff;font-size:10px;font-weight:800;padding:4px 14px 4px 10px;border-radius:0 20px 20px 0;letter-spacing:.5px;text-transform:uppercase;box-shadow:2px 2px 6px rgba(0,0,0,.15);z-index:5}.detail-like{background:#fff0f0;border:none;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .22s;flex-shrink:0;padding:0}.detail-like:hover{transform:scale(1.1)}.detail-name{font-size:18px;font-weight:500;color:#1e293b;line-height:1.3;margin-bottom:6px;font-family:"Nunito","Segoe UI",sans-serif}.detail-price-row{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}.detail-price{font-size:26px;font-weight:900;color:#1e293b}.detail-price-original{font-size:15px;color:#94a3b8;text-decoration:line-through;font-weight:600}.detail-badges{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:10px}.badge-offer{background:#f1f5f9;color:#475569;font-weight:700;padding:4px 10px;border-radius:6px;font-size:12px;border:1px solid #e2e8f0}.badge-instock{background:#f1f5f9;color:#475569;font-weight:700;padding:4px 10px;border-radius:6px;font-size:12px;border:1px solid #e2e8f0}.badge-outstock{background:#f1f5f9;color:#94a3b8;font-weight:700;padding:4px 10px;border-radius:6px;font-size:12px;border:1px solid #e2e8f0}.detail-divider{height:1px;background:#f1f5f9;margin:10px 0}.detail-action-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.detail-qty-box{display:flex;align-items:center;border:2px solid #e2e8f0;border-radius:10px;overflow:hidden;flex-shrink:0}.detail-qty-btn{width:36px;height:42px;border:none;background:#f0f0f0;color:var(--primary);font-size:18px;font-weight:800;cursor:pointer;transition:background .18s;display:flex;align-items:center;justify-content:center}.detail-qty-btn:hover{background:#fee2e2}.detail-qty-val{width:38px;text-align:center;font-weight:800;font-size:15px;color:#1e293b;border:none;background:#fff;outline:0}.detail-add-btn{flex:1;height:42px;background:#1e293b;color:#fff;border:none;border-radius:10px;font-weight:800;font-size:14px;cursor:pointer;transition:all .28s;display:flex;align-items:center;justify-content:center;gap:7px}.detail-add-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.15)}.detail-add-btn:disabled{background:#94a3b8;cursor:not-allowed;transform:none;box-shadow:none}.detail-add-btn.added{background:#1e293b;color:#16a34a;flex:0 0 auto;padding:0 14px;font-size:13px}#detailCheckoutWrapper{display:contents}#detailCheckoutBtn{flex:1;height:42px;background:linear-gradient(135deg,#8b0000,#dc143c);color:#fff;border:none;border-radius:10px;font-weight:800;font-size:13px;cursor:pointer;transition:all .28s;display:flex;align-items:center;justify-content:center;gap:6px;animation:fadeInBtn .2s ease}#detailCheckoutBtn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(139,0,0,.3)}@keyframes fadeInBtn{from{opacity:0;transform:scale(.93)}to{opacity:1;transform:scale(1)}}.detail-info-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.detail-pill{background:#f0f0f0;border:1px solid #e2e8f0;border-radius:8px;padding:8px 12px;font-size:12px;color:#475569;font-weight:600;flex:1;min-width:130px;display:flex;align-items:center;gap:7px}.review-section{background:#f0f0f0;border-radius:12px;padding:16px;margin-top:4px}.review-section-title{font-weight:800;font-size:14px;color:#1e293b;margin-bottom:14px;display:flex;align-items:center;gap:6px}.review-input-box{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:13px 14px;margin-bottom:12px;transition:border-color .22s,box-shadow .22s}.review-input-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(139,0,0,.07)}.review-input-label{font-weight:700;font-size:12px;color:#334155;margin-bottom:8px}.star-selector{display:flex;gap:3px;margin-bottom:10px}.star-btn{background:0 0;border:none;cursor:pointer;font-size:22px;color:#d1d5db;padding:0;transition:all .15s;line-height:1}.star-btn.active{color:#f59e0b}.star-btn:hover{transform:scale(1.2)}.review-textarea{width:100%;min-height:56px;max-height:90px;border:none;outline:0;resize:none;font-family:inherit;font-size:13px;color:#334155;line-height:1.5;background:0 0}.review-textarea::placeholder{color:#94a3b8}.review-submit-row{display:flex;justify-content:flex-end;margin-top:8px}.review-submit-btn{background:#1e293b;color:#fff;border:none;padding:7px 18px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all .22s}.review-submit-btn:hover{background:#334155;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.12)}.review-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.review-login-prompt{background:#fff;border:1.5px dashed #e2e8f0;border-radius:8px;padding:12px 16px;font-size:13px;color:#64748b;margin-bottom:12px;text-align:center}.review-login-prompt a{color:var(--primary);font-weight:700;cursor:pointer;text-decoration:underline}.review-item{background:#fff;padding:12px 13px;border-radius:9px;margin-bottom:8px;box-shadow:0 1px 4px rgba(0,0,0,.05)}.review-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.review-name{font-weight:500;font-size:13px;color:#334155;display:flex;align-items:center;gap:5px;font-family:"Nunito","Segoe UI",sans-serif}.review-rating-stars{color:#f59e0b;font-size:13px}.review-text{font-size:13px;color:#64748b;line-height:1.5}.banner{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:24px;border-radius:16px;margin:24px 0;text-align:center;box-shadow:0 12px 32px rgba(239,68,68,.25)}.banner.blue{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.banner-title{font-size:18px;font-weight:800;margin-bottom:8px}.banner-discount{font-size:36px;font-weight:900;margin:10px 0;letter-spacing:-1px}.banner-desc{font-size:13px;opacity:.95;font-weight:600}.cart-item{background:#f1f5f9;border-radius:14px;padding:14px;margin-bottom:12px;display:flex;gap:12px;align-items:center}.cart-img{width:70px;height:70px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.cart-img img{width:100%;height:100%;object-fit:contain;border-radius:12px}.cart-info{flex:1}.cart-name{font-weight:500;margin-bottom:4px;font-size:14px;font-family:"Nunito","Segoe UI",sans-serif}.cart-price{color:var(--primary);font-weight:800}.qty{display:flex;gap:6px;background:#fff;border-radius:10px;padding:6px;border:2px solid var(--primary);align-items:center}.qty-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;font-weight:800;font-size:16px;transition:all .2s}.qty-btn:hover{transform:scale(1.1)}.qty-val{width:28px;text-align:center;font-weight:700}.checkout-box{background:linear-gradient(135deg,#f8fafc,#ecf0f5);border-radius:14px;padding:20px;margin-top:20px;margin-bottom:20px;border:1.5px solid #e2e8f0}.checkout-row{display:flex;justify-content:space-between;margin-bottom:12px;font-size:14px;font-weight:600;color:#475569}.checkout-total{display:flex;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:2px solid #fff;font-weight:800;font-size:18px;color:var(--primary)}.checkout-btn{width:100%;padding:16px;background:linear-gradient(135deg,#8b0000,#dc143c);color:#fff;border:none;border-radius:12px;font-weight:800;font-size:16px;cursor:pointer;transition:all .3s ease}.checkout-btn:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(139,0,0,.3)}.category-chips{display:flex;gap:10px;overflow-x:auto;padding:14px 0 18px;margin-bottom:8px;scrollbar-width:none}.category-chips::-webkit-scrollbar{display:none}.category-chip{display:flex;flex-direction:column;align-items:center;gap:0;cursor:pointer;flex-shrink:0;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:0;transition:all .2s ease;overflow:hidden;width:80px;box-shadow:0 2px 6px rgba(0,0,0,.04)}.category-chip:hover{transform:translateY(-3px);box-shadow:0 8px 18px rgba(139,0,0,.1);border-color:#c0392b}.chip-img-wrap{width:80px;height:60px;background:#f0f0f0;display:flex;align-items:center;justify-content:center;overflow:hidden}.chip-img-wrap img{width:100%;height:100%;object-fit:cover}.chip-label{font-size:11px;font-weight:600;color:#475569;white-space:nowrap;text-align:center;padding:6px 4px;width:100%;border-top:1px solid #f1f5f9}.category-chip.active{border-color:#c0392b;box-shadow:0 0 0 2px rgba(192,57,43,.18)}.category-chip.active .chip-label{color:#8b0000;font-weight:800;background:#fff5f5}.empty{text-align:center;padding:60px 20px}.empty-icon{margin-bottom:20px;opacity:.35;animation:float 3s ease-in-out infinite;display:flex;justify-content:center}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.skeleton-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;overflow:hidden}.skeleton-img{height:200px}.skeleton-line{height:14px;margin:8px 12px}.skeleton-line.short{width:60%}.skeleton-btn{height:32px;margin:8px 12px 12px;border-radius:8px}@keyframes slideIn{from{transform:translateX(400px);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slideOut{from{transform:translateX(0);opacity:1}to{transform:translateX(400px);opacity:0}}.loading{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.section{display:none}.section.active{display:block;animation:fadeIn .4s ease}.title{font-size:18px;font-weight:700;margin-bottom:20px;color:#334155}@media (max-width:768px){.title{font-size:16px}.coupon-grid{grid-template-columns:repeat(2,1fr)}}