/* ============================================================
 * Nước Hoa Ô tô — Shared component styles (lx-*)
 * Extract từ views/frontend/index.php, dùng chung cho mọi page.
 * ============================================================ */

.lx-cats-wrap{max-width:1440px;margin:0 auto;padding:2.5rem 1rem;font-family:'Work Sans',sans-serif}
@media(min-width:768px){.lx-cats-wrap{padding:2.5rem 2rem}}
.lx-cats-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.lx-cats-title{font-family:'Cormorant Garamond',serif;font-size:1.875rem;font-weight:600;color:#1c1917;margin:0;line-height:1.2}
@media(min-width:768px){.lx-cats-title{font-size:2.25rem}}
.lx-cats-sub{color:#78716c;font-size:0.875rem;margin:0.25rem 0 0}
.lx-cats-more{color:#c5a059;font-size:0.875rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:0.25rem;transition:color 0.2s;white-space:nowrap}
.lx-cats-more:hover{color:#9c7c38}
.lx-cats-more .fas{font-size:1rem}
.lx-cats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.75rem}
@media(min-width:768px){.lx-cats-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.lx-cats-grid{grid-template-columns:repeat(8,1fr)}}
.lx-cat-card{background:#faf9f6;border:1px solid rgba(28,25,23,0.08);border-radius:0.75rem;padding:1.25rem;text-align:center;text-decoration:none;color:inherit;display:block;transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease}
.lx-cat-card:hover{transform:translateY(-4px);box-shadow:0 20px 30px -15px rgba(28,25,23,0.15);border-color:#c5a059}
.lx-cat-thumb{aspect-ratio:1/1;background:#f5f1e8;border-radius:0.5rem;display:flex;align-items:center;justify-content:center;margin-bottom:0.75rem;transition:background-color 0.2s}
.lx-cat-card:hover .lx-cat-thumb{background:rgba(197,160,89,0.1)}
.lx-cat-thumb .fas{color:#c5a059;font-size:2.25rem}
.lx-cat-name{font-size:0.875rem;font-weight:500;color:#1c1917;margin:0 0 0.125rem;line-height:1.25}
.lx-cat-count{font-size:11px;color:#78716c;margin:0}


.lx-sec{max-width:1440px;margin:0 auto;padding:2.5rem 1rem;font-family:'Work Sans',sans-serif}
@media(min-width:768px){.lx-sec{padding:2.5rem 2rem}}
.lx-sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.lx-sec-title{font-family:'Cormorant Garamond',serif;font-size:1.875rem;font-weight:600;color:#1c1917;margin:0;line-height:1.2}
@media(min-width:768px){.lx-sec-title{font-size:2.25rem}}
.lx-sec-sub{color:#78716c;font-size:0.875rem;margin:0.25rem 0 0}
.lx-link-more{color:#c5a059;font-size:0.875rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:0.25rem;transition:color 0.2s;white-space:nowrap}
.lx-link-more:hover{color:#9c7c38}
.lx-link-more .fas{font-size:1rem}

/* ===== FLASH SALE ===== */
.lx-fs{background:linear-gradient(135deg,#c1272d 0%,#a01e23 50%,#1a1410 100%);border-radius:1rem;overflow:hidden}
.lx-fs-inner{display:flex;flex-direction:column}
@media(min-width:1024px){.lx-fs-inner{flex-direction:row}}
.lx-fs-head{padding:1.5rem;color:#faf9f6;display:flex;flex-direction:column;justify-content:space-between}
@media(min-width:1024px){.lx-fs-head{width:18rem;padding:2rem;flex-shrink:0}}
.lx-fs-pill{display:inline-flex;align-items:center;gap:0.5rem;background:rgba(250,249,246,0.15);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:0.375rem 0.75rem;border-radius:9999px;font-size:10px;text-transform:uppercase;letter-spacing:0.1em;font-weight:700;margin-bottom:1rem;animation:lx-pulse 2s ease-in-out infinite;align-self:flex-start}
.lx-fs-pill .fas{color:#c5a059;font-size:14px}
@keyframes lx-pulse{0%,100%{opacity:1}50%{opacity:0.85}}
.lx-fs-title{font-family:'Cormorant Garamond',serif;font-size:2.25rem;font-weight:300;line-height:1.25;margin:0 0 0.5rem;color:#faf9f6}
@media(min-width:1024px){.lx-fs-title{font-size:3rem}}
.lx-fs-title em{font-style:italic;color:#c5a059;font-weight:400}
.lx-fs-end{color:rgba(250,249,246,0.7);font-size:0.875rem;margin:0.75rem 0 0}
.lx-fs-cd{display:flex;align-items:center;gap:0.5rem;margin-top:1rem}
.lx-fs-cd-box{background:rgba(26,20,16,0.6);backdrop-filter:blur(8px);border-radius:0.5rem;padding:0.5rem 0.75rem;text-align:center;min-width:52px}
.lx-fs-cd-num{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:#c5a059;line-height:1}
.lx-fs-cd-lbl{font-size:9px;text-transform:uppercase;letter-spacing:0.05em;color:rgba(250,249,246,0.6);margin-top:0.125rem}
.lx-fs-cd-sep{color:#c5a059;font-size:1.25rem}
.lx-fs-more{color:#faf9f6;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;border-bottom:1px solid #c5a059;display:inline-flex;align-items:center;gap:0.25rem;align-self:flex-start;text-decoration:none;padding-bottom:2px;margin-top:1.5rem;transition:color 0.2s}
.lx-fs-more:hover{color:#c5a059}
.lx-fs-more .fas{font-size:0.875rem}
.lx-fs-scrollwrap{position:relative;flex:1 1 0;min-width:0}
.lx-fs-scroll{padding:1rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;user-select:none}
.lx-fs-scroll::-webkit-scrollbar{display:none}
.lx-fs-scroll.is-dragging{cursor:grabbing;scroll-behavior:auto}
.lx-fs-scroll.is-dragging .lx-fs-card{pointer-events:none}
@media(min-width:1024px){.lx-fs-scroll{padding:1.5rem}}
.lx-fs-track{display:flex;gap:1rem;width:max-content}
.lx-fs-nav{position:absolute;top:50%;transform:translateY(-50%);width:2.5rem;height:2.5rem;border-radius:9999px;background:rgba(250,249,246,0.95);color:#1a1410;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 20px rgba(0,0,0,0.25);z-index:5;transition:background 0.2s,color 0.2s,opacity 0.2s,transform 0.2s;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.lx-fs-nav:hover{background:#c5a059;color:#1a1410}
.lx-fs-nav .fas{font-size:14px}
.lx-fs-nav-prev{left:0.5rem}
.lx-fs-nav-next{right:0.5rem}
.lx-fs-nav[disabled]{opacity:0;pointer-events:none;transform:translateY(-50%) scale(0.85)}
@media(min-width:1024px){.lx-fs-nav{width:2.75rem;height:2.75rem}.lx-fs-nav-prev{left:0.75rem}.lx-fs-nav-next{right:0.75rem}}
.lx-fs-card{background:#faf9f6;border-radius:0.75rem;padding:1rem;width:14rem;flex-shrink:0;text-decoration:none;color:inherit;display:block;transition:box-shadow 0.2s}
.lx-fs-card:hover{box-shadow:0 20px 25px -5px rgba(0,0,0,0.15)}
.lx-fs-name{transition:color 0.2s}
.lx-fs-card:hover .lx-fs-name,
.product-card.lx-fs-card:hover .lx-fs-name,
a.lx-fs-card:hover .lx-fs-name{color:#c5a059 !important}
.lx-fs-img-wrap{position:relative;aspect-ratio:1/1;background:#f5f1e8;border-radius:0.5rem;overflow:hidden;margin-bottom:0.75rem}
.lx-fs-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.lx-ribbon{position:absolute;top:0.5rem;left:0.5rem;background:linear-gradient(135deg,#c1272d 0%,#8c1a1f 100%);color:#faf9f6;font-size:10px;font-weight:700;padding:0.125rem 0.5rem;border-radius:0.25rem}
.lx-fs-name{font-size:0.875rem;font-weight:600;line-height:1.25;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.lx-fs-price{margin-top:0.5rem}
.lx-fs-price-now{color:#c1272d;font-weight:700;font-size:1.125rem}
.lx-fs-price-old{color:#78716c;font-size:0.75rem;text-decoration:line-through}
.lx-fs-bar{margin-top:0.5rem;background:#f5f1e8;border-radius:9999px;overflow:hidden;height:0.5rem}
.lx-fs-bar-fill{background:#c1272d;height:100%}
.lx-fs-sold{font-size:10px;color:#78716c;margin-top:0.375rem}

/* ===== BEST SELLERS ===== */
.lx-bs-tabs{display:flex;align-items:center;gap:0.5rem;flex-wrap:wrap}
.lx-bs-tab{padding:0.5rem 1rem;font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;border-radius:9999px;border:1px solid rgba(28,25,23,0.15);background:transparent;color:#1c1917;cursor:pointer;font-family:inherit;transition:all 0.2s}
.lx-bs-tab:hover{border-color:#1c1917}
.lx-bs-tab.active{background:#1c1917;color:#faf9f6;border-color:#1c1917}
.lx-pgrid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:600px){.lx-pgrid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:768px){.lx-pgrid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}
@media(min-width:1280px){.lx-pgrid{grid-template-columns:repeat(4,1fr)}}
.lx-pcard{background:#faf9f6;border:1px solid rgba(28,25,23,0.08);border-radius:0.75rem;overflow:hidden;transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease;position:relative}
.lx-pcard:hover{transform:translateY(-4px);box-shadow:0 20px 30px -15px rgba(28,25,23,0.15);border-color:#c5a059}
.lx-pcard a{text-decoration:none;color:inherit;display:block}
.lx-pcard-img{position:relative;aspect-ratio:1/1;background:#f5f1e8;overflow:hidden}
.lx-pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s cubic-bezier(0.16,1,0.3,1);display:block}
.lx-pcard:hover .lx-pcard-img img{transform:scale(1.08)}
.lx-badge-sale{position:absolute;top:0.75rem;left:0.75rem;background:#c1272d;color:#faf9f6;font-size:10px;font-weight:700;padding:0.25rem 0.5rem;border-radius:0.25rem}
.lx-badge-new,.lx-badge-hot,.lx-badge-best{position:absolute;top:0.75rem;right:0.75rem;font-size:10px;font-weight:700;padding:0.25rem 0.5rem;border-radius:0.25rem}
.lx-badge-new,.lx-badge-hot{background:#c5a059;color:#1a1410}
.lx-badge-best{background:#0c8347;color:#faf9f6}
.lx-pcard-actions{position:absolute;left:0.75rem;right:0.75rem;bottom:0.75rem;display:flex;gap:0.5rem;transform:translateY(3rem);transition:transform 0.3s ease}
.lx-pcard:hover .lx-pcard-actions{transform:translateY(0)}
.lx-pcard-add{flex:1;background:#faf9f6;color:#1c1917;border:none;padding:0.5rem;font-size:0.75rem;font-weight:700;text-transform:uppercase;border-radius:0.25rem;cursor:pointer;transition:background 0.2s,color 0.2s;font-family:inherit}
.lx-pcard-add:hover{background:#1c1917;color:#faf9f6}
.lx-pcard-fav{width:2.25rem;height:2.25rem;background:#faf9f6;color:#1c1917;border:none;border-radius:0.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.2s,color 0.2s}
.lx-pcard-fav:hover{background:#c5a059;color:#faf9f6}
.lx-pcard-fav .fas{font-size:1rem}
.lx-pcard-body{padding:1rem}
.lx-pcard-brand{font-size:10px;color:#c5a059;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:0.25rem}
.lx-pcard-name{font-size:0.875rem;font-weight:600;line-height:1.35;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;height:2.5rem;transition:color 0.2s}
.lx-pcard:hover .lx-pcard-name{color:#c5a059}
.lx-pcard-rate{display:flex;align-items:center;gap:0.25rem;margin:0.5rem 0;font-size:0.75rem}
.lx-pcard-rate-stars{color:#c5a059}
.lx-pcard-rate-count{color:#78716c;font-size:11px}
.lx-pcard-price{display:flex;align-items:baseline;gap:0.5rem}
.lx-pcard-price-now{font-weight:700;font-size:1rem;color:#1c1917}
.lx-pcard-price-now.sale{color:#c1272d}
.lx-pcard-price-old{color:#78716c;font-size:0.75rem;text-decoration:line-through}
.lx-pcard-stock{font-size:11px;font-weight:500;margin-top:0.25rem;display:flex;align-items:center;gap:0.25rem}
.lx-pcard-stock.ok{color:#0c8347}
.lx-pcard-stock.hot{color:#c1272d}
.lx-pcard-stock .fas{font-size:12px}
.lx-bs-foot{margin-top:2rem;text-align:center}
.lx-btn-outline{display:inline-flex;align-items:center;gap:0.5rem;border:2px solid #1c1917;color:#1c1917;background:transparent;padding:0.75rem 2rem;font-size:0.875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.15em;text-decoration:none;cursor:pointer;font-family:inherit;transition:background 0.2s,color 0.2s}
.lx-btn-outline:hover{background:#1c1917;color:#faf9f6}
.lx-btn-outline .fas{font-size:1rem}

/* ===== BRAND SHOWCASE ===== */
.lx-brand-wrap{background:#1a1410;border-radius:1rem;padding:1.5rem 1rem;color:#faf9f6}
@media(min-width:640px){.lx-brand-wrap{padding:2rem}}
@media(min-width:768px){.lx-brand-wrap{padding:3rem}}
.lx-brand-head{text-align:center;margin-bottom:2rem}
@media(min-width:768px){.lx-brand-head{margin-bottom:2.5rem}}
.lx-brand-eyebrow{color:#c5a059;font-size:2.8rem;font-family:'Cormorant Garamond',serif;letter-spacing:0.0em;font-weight:600;padding-bottom:10px;line-height:1.3;}
.lx-brand-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;margin:0.75rem 0 0;color:#faf9f6;line-height:1.2}
@media(min-width:640px){.lx-brand-title{font-size:1.5rem}}
@media(min-width:768px){.lx-brand-title{font-size:3rem}}
.lx-brand-title em{font-style:italic;color:#c5a059;font-weight:400;white-space:nowrap}
.lx-brand-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.75rem}
@media(min-width:640px){.lx-brand-grid{gap:1rem}}
@media(min-width:1024px){.lx-brand-grid{grid-template-columns:repeat(4,1fr)}}
.lx-brand-card{border:1px solid rgba(250,249,246,0.15);border-radius:0.75rem;padding:1rem 0.5rem;text-align:center;text-decoration:none;color:#faf9f6;transition:border-color 0.2s;display:block;min-width:0;overflow:hidden}
@media(min-width:640px){.lx-brand-card{padding:1.5rem}}
.lx-brand-card:hover{border-color:#c5a059}
.lx-brand-name{font-family:'Cormorant Garamond',serif;font-size:1.125rem;font-weight:700;margin:0 0 0.25rem;transition:color 0.2s;line-height:1.1;word-break:break-word}
@media(min-width:640px){.lx-brand-name{font-size:1.5rem}}
@media(min-width:1024px){.lx-brand-name{font-size:1.875rem}}
.lx-brand-card:hover .lx-brand-name{color:#c5a059}
.lx-brand-meta{color:rgba(250,249,246,0.5);font-size:9px;text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.5rem;line-height:1.3}
@media(min-width:640px){.lx-brand-meta{font-size:10px;letter-spacing:0.15em;margin-bottom:0.75rem}}
.lx-brand-count{color:rgba(250,249,246,0.7);font-size:0.75rem}
.lx-brand-cta{margin-top:0.75rem;color:#c5a059;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.05em;font-weight:700}

/* ===== SHOP BY USE CASE ===== */
.lx-uc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(min-width:768px){.lx-uc-grid{grid-template-columns:repeat(3,1fr);gap:0.875rem}}
@media(min-width:992px){.lx-uc-grid{grid-template-columns:repeat(5,1fr);gap:0.75rem}}
@media(min-width:992px){.lx-uc-card{height:16rem}}
.lx-uc-card{position:relative;height:18rem;border-radius:0.75rem;overflow:hidden;text-decoration:none;display:block;color:#faf9f6}
.lx-uc-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;display:block}
.lx-uc-card:hover img{transform:scale(1.05)}
.lx-uc-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.92) 0%,rgba(0,0,0,0.75) 25%,rgba(0,0,0,0.35) 55%,rgba(0,0,0,0.05) 85%,transparent 100%);pointer-events:none}
.lx-uc-body{position:absolute;left:1.25rem;right:1.25rem;bottom:1.25rem;color:#faf9f6;text-shadow:0 1px 4px rgba(0,0,0,0.55)}
.lx-uc-tag{background:#c5a059;color:#1a1410;font-size:9px;text-transform:uppercase;letter-spacing:0.15em;font-weight:700;padding:0.25rem 0.5rem;border-radius:0.25rem;text-shadow:none;display:inline-block;box-shadow:0 2px 6px rgba(0,0,0,0.25)}
.lx-uc-name{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;margin:0.5rem 0 0.25rem;line-height:1.2;color:#fff}
.lx-uc-desc{font-size:0.8125rem;color:rgba(255,255,255,0.92);margin:0;line-height:1.45}
.lx-uc-cta{display:inline-block;margin-top:0.75rem;color:#c5a059;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.05em;font-weight:700;border-bottom:1px solid #c5a059;padding-bottom:2px;text-shadow:none}

/* ===== AREON SPOTLIGHT ===== */
.lx-sp-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:1024px){.lx-sp-grid{grid-template-columns:1fr 3fr}}
.lx-sp-hero{background:linear-gradient(135deg,#1a1410 0%,#2a2520 100%);border-radius:1rem;padding:2rem;color:#faf9f6;display:flex;flex-direction:column;justify-content:space-between;gap:1.5rem}
.lx-sp-eyebrow{color:#c5a059;font-size:10px;text-transform:uppercase;letter-spacing:0.3em;font-weight:700}
.lx-sp-title{font-family:'Cormorant Garamond',serif;font-size:2.25rem;font-weight:300;line-height:1.1;margin:0.75rem 0 1rem;color:#faf9f6}
.lx-sp-title em{font-style:italic;color:#c5a059;font-size:1.5rem;display:block;font-weight:400}
.lx-sp-desc{color:rgba(250,249,246,0.7);font-size:0.875rem;line-height:1.65;margin:0}
.lx-sp-btn{align-self:flex-start;display:inline-flex;align-items:center;gap:0.5rem;background:#c5a059;color:#1a1410;padding:0.625rem 1.25rem;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;text-decoration:none;transition:background 0.2s}
.lx-sp-btn:hover{background:#f5e9c8}
.lx-sp-btn .fas{font-size:1rem}
.lx-sp-items{display:grid;grid-template-columns:repeat(2,1fr);gap:0.75rem}
@media(min-width:768px){.lx-sp-items{grid-template-columns:repeat(3,1fr)}}
.lx-sp-card{background:#faf9f6;border:1px solid rgba(28,25,23,0.08);border-radius:0.75rem;overflow:hidden;text-decoration:none;color:inherit;display:block;transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease}
.lx-sp-card:hover{transform:translateY(-4px);box-shadow:0 20px 30px -15px rgba(28,25,23,0.15);border-color:#c5a059}
.lx-sp-card-img{aspect-ratio:1/1;background:#f5f1e8;overflow:hidden}
.lx-sp-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;display:block}
.lx-sp-card:hover .lx-sp-card-img img{transform:scale(1.08)}
.lx-sp-card-body{padding:0.75rem}
.lx-sp-card-name{font-size:0.75rem;font-weight:600;line-height:1.25;margin:0 0 0.25rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;height:2rem}
.lx-sp-card-price{display:flex;align-items:baseline;gap:0.5rem}
.lx-sp-card-price-now{font-weight:700;font-size:0.875rem;color:#1c1917}
.lx-sp-card-price-old{font-size:10px;color:#78716c;text-decoration:line-through}

/* ===== CUSTOMER REVIEWS ===== */
.lx-rv-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:1280px){.lx-rv-grid{grid-template-columns:1fr 2fr}}
.lx-rv-summary-title{font-family:'Cormorant Garamond',serif;font-size:1.875rem;font-weight:600;margin:0.5rem 0 1rem;color:#1c1917;line-height:1.2}
@media(min-width:768px){.lx-rv-summary-title{font-size:1.75rem}}
.lx-rv-summary-title em{font-style:italic;color:#c5a059;font-weight:400}
.lx-rv-summary-desc{color:#78716c;font-size:0.875rem;margin:0 0 1.5rem;line-height:1.6}
.lx-rv-summary-stats{display:flex;align-items:flex-start;gap:1rem}
.lx-rv-avg{flex-shrink:0}
.lx-rv-avg-num{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:600;color:#c5a059;line-height:1}
.lx-rv-avg-stars{color:#c5a059;font-size:1rem;margin-top:0.25rem}
.lx-rv-avg-count{color:#78716c;font-size:0.75rem;margin-top:0.25rem}
.lx-rv-bars{flex:1;display:flex;flex-direction:column;gap:0.375rem}
.lx-rv-bar-row{display:flex;align-items:center;gap:0.5rem;font-size:0.75rem}
.lx-rv-bar-lbl{width:0.75rem}
.lx-rv-bar{flex:1;background:#f5f1e8;border-radius:9999px;height:6px;overflow:hidden}
.lx-rv-bar-fill{background:#c5a059;height:100%}
.lx-rv-bar-pct{color:#78716c}
.lx-rv-cards{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:1280px){.lx-rv-cards{grid-template-columns:repeat(2,1fr)}}
.lx-rv-card{background:#faf9f6;border:1px solid rgba(28,25,23,0.08);border-radius:0.75rem;padding:1.25rem;transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease}
.lx-rv-card:hover{transform:translateY(-4px);box-shadow:0 20px 30px -15px rgba(28,25,23,0.15);border-color:#c5a059}
.lx-rv-head{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem}
.lx-rv-avatar{width:2.5rem;height:2.5rem;border-radius:9999px;background:#f5f1e8;display:flex;align-items:center;justify-content:center;font-weight:700;color:#c5a059;font-size:0.875rem;flex-shrink:0}
.lx-rv-meta{flex:1}
.lx-rv-name{font-size:0.875rem;font-weight:600;color:#1c1917}
.lx-rv-car{font-size:10px;color:#78716c;text-transform:uppercase;letter-spacing:0.05em;margin-top:0.125rem}
.lx-rv-stars{color:#c5a059;font-size:0.75rem}
.lx-rv-product{font-size:11px;font-weight:700;color:#c5a059;margin:0 0 0.25rem}
.lx-rv-text{color:#78716c;font-size:0.875rem;line-height:1.6;margin:0}

/* ===== KNOWLEDGE / BLOG ===== */
.lx-bl-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:768px){.lx-bl-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.lx-bl-grid{grid-template-columns:repeat(4,1fr)}}
.lx-bl-card{background:#faf9f6;border:1px solid rgba(28,25,23,0.08);border-radius:0.75rem;overflow:hidden;transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease}
.lx-bl-card:hover{transform:translateY(-4px);box-shadow:0 20px 30px -15px rgba(28,25,23,0.15);border-color:#c5a059}
.lx-bl-card a{text-decoration:none;color:inherit;display:block}
.lx-bl-img{aspect-ratio:16/10;overflow:hidden;background:#f5f1e8}
.lx-bl-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;display:block}
.lx-bl-card:hover .lx-bl-img img{transform:scale(1.08)}
.lx-bl-body{padding:1rem}
.lx-bl-meta{display:flex;align-items:center;gap:0.75rem;font-size:10px;color:#78716c;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:0.5rem}
.lx-bl-meta-cat{color:#c5a059;font-weight:700}
.lx-bl-title{font-size:1rem;font-weight:600;line-height:1.4;color:#1c1917;margin:0;transition:color 0.2s;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lx-bl-card:hover .lx-bl-title{color:#c5a059}

/* ===== NEWSLETTER + B2B ===== */
.lx-nl-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:1024px){.lx-nl-grid{grid-template-columns:repeat(2,1fr)}}
.lx-nl-card{border-radius:1rem;padding:2rem}
@media(min-width:768px){.lx-nl-card{padding:2.5rem}}
.lx-nl-b2b{background:linear-gradient(135deg,#c5a059 0%,#9c7c38 100%);color:#1a1410}
.lx-nl-vip{background:#1a1410;color:#faf9f6}
.lx-nl-eyebrow{font-size:10px;text-transform:uppercase;letter-spacing:0.3em;font-weight:700}
.lx-nl-vip .lx-nl-eyebrow{color:#c5a059}
.lx-nl-title{font-family:'Cormorant Garamond',serif;font-size:1.875rem;font-weight:600;line-height:1.15;margin:0.5rem 0 0.75rem}
@media(min-width:768px){.lx-nl-title{font-size:2.25rem}}
.lx-nl-title em{font-style:italic}
.lx-nl-vip .lx-nl-title {color:#fff}
.lx-nl-vip .lx-nl-title em{color:#c5a059}
.lx-nl-desc{font-size:0.875rem;margin:0 0 1.5rem;max-width:28rem;line-height:1.6}
.lx-nl-b2b .lx-nl-desc{color:rgba(26,20,16,0.8)}
.lx-nl-vip .lx-nl-desc{color:rgba(250,249,246,0.7)}
.lx-nl-btn{display:inline-flex;align-items:center;gap:0.5rem;background:#1a1410;color:#c5a059;padding:0.75rem 1.5rem;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.15em;text-decoration:none;transition:background 0.2s}
.lx-nl-btn:hover{background:#1c1917}
.lx-nl-btn .fas{font-size:1rem}
.lx-nl-form{display:flex;gap:0.5rem}
.lx-nl-input{flex:1;background:#2a2520;border:1px solid rgba(250,249,246,0.15);color:#faf9f6;padding:0.75rem 1rem;font-size:0.875rem;border-radius:0.25rem;outline:none;font-family:inherit;transition:border-color 0.2s}
.lx-nl-input::placeholder{color:rgba(250,249,246,0.4)}
.lx-nl-input:focus{border-color:#c5a059}
.lx-nl-submit{background:#c5a059;color:#1a1410;border:none;padding:0 1.5rem;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.15em;cursor:pointer;border-radius:0.25rem;font-family:inherit;transition:background 0.2s}
.lx-nl-submit:hover{background:#f5e9c8}

/* ============================================================
 * CATE PAGE (extract từ views/frontend/product/cate.php)
 * Filter sidebar, hero, ptype-scroll hint, blog section
 * ============================================================ */

.filter-advanced-header{display:flex;align-items:center;justify-content:space-between;gap:0.5rem;color:#C5A059;font-weight:700;font-size:0.9375rem;letter-spacing:0.15em;padding:1rem 0;margin-bottom:1.25rem;border-bottom:1px solid #f0ebe0;border-radius:8px;margin-top:-0.5rem}
.filter-advanced-header .material-symbols-outlined{font-size:1.25rem;color:#C5A059}
.filter-section-title-scent{font-size:0.875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;color:#333;margin-bottom:0.75rem}
.filter-tags{display:flex;flex-wrap:wrap;gap:0.5rem}
.filter-tag{display:inline-block;padding:0.2rem 0.3rem;border-radius:9999px;border:1px solid #e8dfc5;background:#faf6ee;color:#555;font-size:0.8125rem;font-weight:500;text-decoration:none;transition:all 0.3s ease;cursor:pointer}
.filter-tag:hover,.filter-tag.active{border-color:#C5A059;background:rgba(197,160,89,0.15);color:#C5A059;text-decoration:none}
/* HERO CATE INFO */
.hci-wrap{position:relative;border-radius:12px;overflow:hidden;min-height:260px;display:flex;align-items:center;background-size:cover;background-position:center;background-repeat:no-repeat}
.hci-overlay{position:absolute;inset:0;background:rgba(10,9,8,0.58);z-index:1}
.hci-body{position:relative;z-index:2;padding:2.5rem 2rem;max-width:540px}
.hci-breadcrumb{display:flex;align-items:center;gap:0.35rem;font-size:0.7rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:#C5A059;margin-bottom:1rem}
.hci-breadcrumb a{color:#C5A059;text-decoration:none}
.hci-breadcrumb a:hover{text-decoration:underline}
.hci-breadcrumb .sep{opacity:0.7}
.hci-title{font-size:2rem;font-weight:800;color:#fff;margin:0 0 0.75rem;line-height:1.2}
.hci-desc{color:rgba(255,255,255,0.75);font-size:0.875rem;line-height:1.7;margin:0;max-width:380px}
.hci-btn{display:inline-flex;align-items:center;gap:0.5rem;margin-top:1.25rem;padding:0.6rem 1.25rem;background:#C5A059;color:#111;font-size:0.875rem;font-weight:700;border-radius:6px;text-decoration:none;transition:background 0.2s,transform 0.2s;line-height:1}
.hci-btn:hover{background:#d2aa60;color:#111;transform:translateY(-1px);text-decoration:none}
.hci-btn-icon{width:1.2rem;height:1.2rem;border-radius:50%;border:1.5px solid rgba(20,20,20,0.45);display:inline-flex;align-items:center;justify-content:center;font-size:0.78rem;font-weight:900;flex-shrink:0}
@media(max-width:767px){.hci-wrap{min-height:200px;border-radius:8px}.hci-body{padding:1.75rem 1.25rem}.hci-title{font-size:1.4rem}.hci-desc{font-size:0.8125rem;max-width:100%}}
/* PRODUCT TYPE GRID */
.ptype-scroll{position:relative;display:flex;gap:0.75rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:0.25rem;cursor:grab;user-select:none}
.ptype-scroll:active,.ptype-scroll.is-dragging{cursor:grabbing}
.ptype-scroll.is-dragging a{pointer-events:none}
.ptype-scroll-wrap{position:relative}
.ptype-scroll-wrap::before,.ptype-scroll-wrap::after{content:'';position:absolute;top:0;bottom:0.5rem;width:32px;pointer-events:none;z-index:2;opacity:0;transition:opacity 0.2s}
.ptype-scroll-wrap::before{left:0;background:linear-gradient(to right,#fff 0%,rgba(255,255,255,0) 100%)}
.ptype-scroll-wrap::after{right:0;background:linear-gradient(to left,#fff 0%,rgba(255,255,255,0) 100%)}
.ptype-scroll-wrap[data-can-prev="1"]::before{opacity:1}
.ptype-scroll-wrap[data-can-next="1"]::after{opacity:1}
.ptype-scroll-hint{position:absolute;top:50%;margin-top:-22px;width:44px;height:44px;border:none;padding:0;border-radius:50%;background:#c5a059;box-shadow:0 6px 18px rgba(197,160,89,0.45),0 0 0 4px rgba(197,160,89,0.18);display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;cursor:pointer;z-index:10;opacity:1;pointer-events:auto;transition:opacity 0.25s,background 0.2s;animation:ptype-hint-pulse 1.4s ease-in-out infinite}
.ptype-scroll-wrap[data-can-next="0"] .ptype-scroll-hint.is-next,.ptype-scroll-wrap[data-can-prev="0"] .ptype-scroll-hint.is-prev{opacity:0;animation:none;pointer-events:none}
.ptype-scroll-hint[disabled],.ptype-scroll-wrap[data-can-prev="0"] .ptype-scroll-hint.is-prev,.ptype-scroll-wrap[data-can-next="0"] .ptype-scroll-hint.is-next{pointer-events:none}
.ptype-scroll-hint:hover{background:#b18d4a}
.ptype-scroll-hint.is-next{right:0.5rem}
.ptype-scroll-hint.is-prev{left:0.5rem}
.ptype-scroll-wrap[data-can-prev="1"] .ptype-scroll-hint.is-prev{animation-delay:0.7s}
@keyframes ptype-hint-pulse{0%,100%{box-shadow:0 6px 18px rgba(197,160,89,0.45),0 0 0 4px rgba(197,160,89,0.18);transform:scale(1)}50%{box-shadow:0 8px 24px rgba(197,160,89,0.65),0 0 0 10px rgba(197,160,89,0.10);transform:scale(1.08)}}
.ptype-scroll::-webkit-scrollbar{height:4px}
.ptype-scroll::-webkit-scrollbar-track{background:transparent}
.ptype-scroll::-webkit-scrollbar-thumb{background:#ddd;border-radius:4px}
.ptype-card{position:relative;border-radius:8px;overflow:hidden;flex:0 0 calc(25% - 0.57rem);min-width:220px;aspect-ratio:4/2;background:#e8e8e8;display:block;text-decoration:none;scroll-snap-align:start}
.ptype-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.35s ease}
.ptype-card:hover img{transform:scale(1.04)}
.ptype-card-foot{position:absolute;bottom:0;left:0;right:0;padding:2rem 0.85rem 0.75rem;background:linear-gradient(to top,rgba(0,0,0,0.62) 0%,rgba(0,0,0,0) 100%)}
.ptype-card-label{color:#fff;font-size:0.9rem;font-weight:700;line-height:1.3}
@media(max-width:767px){.ptype-card{flex:0 0 70vw;min-width:unset;aspect-ratio:4/2}}
/* lx-cat-card khi đặt trong .ptype-scroll: không co lại, scroll snap, width cố định */
.ptype-scroll .lx-cat-card{flex:0 0 auto;width:9.5rem;scroll-snap-align:start}
@media(max-width:767px){.ptype-scroll .lx-cat-card{width:8rem}}
/* BLOG SECTION */
.blog-section{padding:2.5rem 0}
.blog-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.blog-section-title{font-size:1rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:#1a1a1a;margin:0;line-height:1.3}
.blog-section-link{font-size:0.8125rem;font-weight:600;color:#C5A059;text-decoration:none;white-space:nowrap;transition:opacity 0.2s}
.blog-section-link:hover{opacity:0.75;text-decoration:none;color:#C5A059}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{display:block;text-decoration:none;color:inherit}
.blog-card:hover{text-decoration:none;color:inherit}
.blog-card-thumb{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:8px;display:block;background:#e5e5e5;margin-bottom:0.875rem;transition:transform 0.3s ease}
.blog-card:hover .blog-card-thumb{transform:scale(1.02)}
.blog-card-title{font-size:0.9375rem;font-weight:600;color:#1a1a1a;line-height:1.45;margin:0 0 0.4rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-desc{font-size:0.8125rem;color:#777;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:767px){.blog-grid{grid-template-columns:1fr}.blog-section{padding:1.5rem 0}}
