/* ============================================================
   PPK Power Life World — Supplement Brand · Minimal & Chic · Mobile-First
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

/* --- Variables --- */
:root {
  --c-bg:        #F6F4EF;
  --c-surface:   #FFFFFF;
  --c-surface-2: #EEEBE4;
  --c-border:    #DAD6CD;
  --c-text:      #1A1714;
  --c-text-2:    #5C554E;
  --c-muted:     #8C847A;
  --c-orange:    #D46422;
  --c-orange-h:  #B85018;
  --c-orange-bg: #FDF0E8;
  --c-gold:      #C49626;
  --c-gold-l:    #DEB84A;
  --c-gold-d:    #9A7418;
  --c-gold-bg:   #FDF8E8;
  --font-serif:  'Playfair Display', Georgia, serif;
  --font-sans:   'DM Sans', -apple-system, sans-serif;
  --nav-h:       60px;
  --r-sm:  6px; --r-md: 12px; --r-lg: 20px; --r-xl: 28px; --r-full: 9999px;
  --sh-sm: 0 1px 4px rgba(0,0,0,.08);
  --sh-md: 0 4px 18px rgba(0,0,0,.10);
  --sh-lg: 0 8px 36px rgba(0,0,0,.14);
  --tr:    .25s ease;
  --tr-sl: .4s ease;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:var(--font-sans);background:var(--c-bg);color:var(--c-text);font-size:15px;line-height:1.6;min-height:100vh;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}
input,textarea,select{font-family:inherit;font-size:inherit;outline:none}
h1,h2,h3,h4,h5{font-family:var(--font-serif);font-weight:600;line-height:1.25}

/* --- Utility --- */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 26px;border-radius:var(--r-full);font-size:14px;font-weight:500;transition:all var(--tr);cursor:pointer;letter-spacing:.3px;white-space:nowrap}
.btn-primary{background:var(--c-orange);color:#fff}
.btn-primary:hover{background:var(--c-orange-h);transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-gold{background:linear-gradient(135deg,var(--c-gold),var(--c-gold-l));color:#fff}
.btn-gold:hover{background:linear-gradient(135deg,var(--c-gold-d),var(--c-gold));transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-outline{border:1.5px solid var(--c-border);color:var(--c-text);background:transparent}
.btn-outline:hover{border-color:var(--c-orange);color:var(--c-orange)}
.btn-ghost{color:var(--c-text-2);background:transparent}
.btn-ghost:hover{color:var(--c-text)}
.btn-sm{padding:8px 16px;font-size:13px}
.btn-danger{background:#EF4444;color:#fff}
.btn-danger:hover{background:#DC2626}

/* --- Badges --- */
.badge{display:inline-block;padding:3px 10px;border-radius:var(--r-full);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.badge-gold{background:linear-gradient(135deg,var(--c-gold),var(--c-gold-l));color:#fff}
.badge-orange{background:var(--c-orange);color:#fff}
.badge-new{background:var(--c-text);color:#fff}

/* --- Section helpers --- */
.section{padding:44px 0}
.section-head{padding:0 20px;margin-bottom:28px}
.section-title{font-size:26px;color:var(--c-text);margin-bottom:6px}
.section-sub{font-size:13px;color:var(--c-muted)}
.see-all{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--c-orange);font-weight:500;margin-top:10px}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);background:rgba(255,255,255,.95);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--c-border);display:flex;align-items:center}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 16px}
.nav-logo{font-family:var(--font-serif);font-size:18px;font-weight:700;color:var(--c-text);letter-spacing:2.5px;display:flex;align-items:center;gap:5px;cursor:pointer}
.nav-logo .star{color:var(--c-gold);font-size:12px}
.nav-actions{display:flex;align-items:center;gap:2px}
.nav-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);color:var(--c-text);transition:background var(--tr);position:relative}
.nav-btn:hover{background:var(--c-surface-2)}
.nav-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cart-badge{position:absolute;top:5px;right:5px;width:16px;height:16px;background:var(--c-orange);color:#fff;border-radius:50%;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}

/* Mobile Menu */
.mobile-menu{position:fixed;inset:0;z-index:200;background:#fff;transform:translateX(-100%);transition:transform var(--tr-sl);display:flex;flex-direction:column}
.mobile-menu.open{transform:translateX(0)}
.mm-header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--c-border)}
.mm-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);color:var(--c-text)}
.mm-close:hover{background:var(--c-surface-2)}
.mm-body{flex:1;padding:24px 20px;display:flex;flex-direction:column;gap:4px}
.mm-item{padding:16px 0;font-size:20px;font-family:var(--font-serif);color:var(--c-text);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:color var(--tr)}
.mm-item:hover{color:var(--c-orange)}
.mm-item:last-child{border-bottom:none}
.mm-footer{padding:24px 20px;border-top:1px solid var(--c-border)}
.mm-socials{display:flex;gap:12px}
.mm-social{width:38px;height:38px;background:var(--c-surface-2);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:16px}
.overlay-bg{position:fixed;inset:0;z-index:150;background:rgba(26,23,20,.5);opacity:0;pointer-events:none;transition:opacity var(--tr)}
.overlay-bg.show{opacity:1;pointer-events:all}

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search-overlay{position:fixed;top:0;left:0;right:0;z-index:300;background:#fff;transform:translateY(-100%);transition:transform var(--tr-sl);max-height:80vh;overflow-y:auto;box-shadow:var(--sh-lg)}
.search-overlay.open{transform:translateY(0)}
.search-wrap{padding:16px 20px}
.search-row{display:flex;align-items:center;gap:12px;border:1.5px solid var(--c-border);border-radius:var(--r-full);padding:10px 18px;background:var(--c-bg);transition:border-color var(--tr)}
.search-row:focus-within{border-color:var(--c-gold)}
.search-row svg{width:18px;height:18px;color:var(--c-muted);flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.search-input{flex:1;border:none;background:transparent;font-size:16px;color:var(--c-text)}
.search-input::placeholder{color:var(--c-muted)}
.search-close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);color:var(--c-muted);flex-shrink:0}
.search-close-btn:hover{background:var(--c-surface-2);color:var(--c-text)}
.search-results{padding:4px 20px 20px}
.search-empty{text-align:center;padding:32px;color:var(--c-muted);font-size:14px}
.search-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r-md);cursor:pointer;transition:background var(--tr)}
.search-item:hover{background:var(--c-surface-2)}
.search-item-img{width:50px;height:50px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.search-item-name{font-size:14px;font-weight:500;margin-bottom:3px}
.search-item-price{font-size:13px;color:var(--c-orange);font-weight:600}

/* ============================================================
   MAIN APP
   ============================================================ */
#app{padding-top:var(--nav-h);min-height:100vh}
.view{display:none}
.view.active{display:block}

/* ============================================================
   HOME — HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#1A1714 0%,#2C241C 55%,#3A2E22 100%);min-height:88vh;display:flex;align-items:center}
.hero-content{position:relative;z-index:2;padding:60px 20px 80px;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(196,150,38,.12);border:1px solid rgba(196,150,38,.35);color:var(--c-gold-l);padding:6px 14px;border-radius:var(--r-full);font-size:11px;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:22px}
.hero-title{font-size:38px;color:#fff;line-height:1.18;margin-bottom:16px;white-space:pre-line}
.hero-title .hl{background:linear-gradient(135deg,var(--c-gold),var(--c-gold-l));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-size:14px;color:rgba(255,255,255,.6);margin-bottom:34px;white-space:pre-line;line-height:1.75}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-deco{position:absolute;right:-80px;top:50%;transform:translateY(-50%);width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(196,150,38,.12) 0%,transparent 65%);pointer-events:none}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:5px;color:rgba(255,255,255,.35);font-size:10px;letter-spacing:1.5px;animation:bounce 2.4s infinite}
.hero-scroll svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Stats Strip */
.stats-strip{background:#fff;border-bottom:1px solid var(--c-border);display:grid;grid-template-columns:repeat(3,1fr)}
.stat{padding:18px 8px;text-align:center;border-right:1px solid var(--c-border)}
.stat:last-child{border-right:none}
.stat-n{font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--c-orange);line-height:1}
.stat-l{font-size:10px;color:var(--c-muted);margin-top:4px;letter-spacing:.3px}

/* Categories */
.cats-scroll{display:flex;gap:10px;overflow-x:auto;padding:4px 20px 12px;scrollbar-width:none;scroll-snap-type:x mandatory}
.cats-scroll::-webkit-scrollbar{display:none}
.cat-chip{flex-shrink:0;display:flex;align-items:center;gap:7px;padding:10px 18px;background:#fff;border:1.5px solid var(--c-border);border-radius:var(--r-full);font-size:13px;font-weight:500;color:var(--c-text-2);transition:all var(--tr);cursor:pointer;scroll-snap-align:start;white-space:nowrap}
.cat-chip:hover,.cat-chip.active{background:var(--c-text);border-color:var(--c-text);color:#fff}
.cat-chip .icon{font-size:17px}

/* Product Cards Grid */
.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;padding:0 20px}
.product-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:all var(--tr);cursor:pointer;position:relative}
.product-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.pc-img{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:56px;position:relative;overflow:hidden}
.pc-img-bg{position:absolute;inset:0}
.pc-emoji{position:relative;z-index:1;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}
.pc-badge{position:absolute;top:10px;left:10px;z-index:2}
.pc-body{padding:13px}
.pc-name{font-size:13px;font-weight:600;color:var(--c-text);line-height:1.35;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pc-sub{font-size:11px;color:var(--c-muted);margin-bottom:10px}
.pc-footer{display:flex;align-items:center;justify-content:space-between}
.pc-price-now{font-size:15px;font-weight:700;color:var(--c-orange)}
.pc-price-old{font-size:11px;color:var(--c-muted);text-decoration:line-through}
.pc-add{width:32px;height:32px;background:var(--c-orange);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:19px;transition:all var(--tr);flex-shrink:0;line-height:1}
.pc-add:hover{background:var(--c-orange-h);transform:scale(1.12)}

/* Benefits */
.benefits{background:var(--c-text);padding:52px 20px;color:#fff}
.benefits .section-title{color:#fff}
.benefits .section-sub{color:rgba(255,255,255,.5)}
.benefits-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:32px}
.benefit{display:flex;flex-direction:column;gap:10px}
.benefit-icon{width:46px;height:46px;background:rgba(196,150,38,.12);border:1px solid rgba(196,150,38,.28);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px}
.benefit-title{font-size:14px;font-weight:600;color:#fff}
.benefit-desc{font-size:12px;color:rgba(255,255,255,.5);line-height:1.65}

/* Testimonials */
.testi-section{padding:48px 0;background:var(--c-surface-2)}
.testi-scroll{display:flex;gap:14px;overflow-x:auto;padding:8px 20px 16px;scrollbar-width:none}
.testi-scroll::-webkit-scrollbar{display:none}
.testi-card{flex-shrink:0;width:260px;background:#fff;border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm)}
.testi-stars{color:var(--c-gold);font-size:13px;margin-bottom:10px;letter-spacing:2px}
.testi-text{font-size:13px;color:var(--c-text-2);line-height:1.68;margin-bottom:14px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:10px}
.testi-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--c-gold),var(--c-orange));display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;font-weight:700;font-family:var(--font-serif);flex-shrink:0}
.testi-name{font-size:13px;font-weight:600}
.testi-loc{font-size:11px;color:var(--c-muted)}

/* Newsletter */
.newsletter{background:linear-gradient(135deg,var(--c-gold-d),var(--c-gold));padding:52px 20px;text-align:center;color:#fff}
.newsletter h2{font-size:24px;margin-bottom:10px}
.newsletter p{font-size:13px;opacity:.85;margin-bottom:22px}
.nl-form{display:flex;gap:8px;max-width:400px;margin:0 auto}
.nl-input{flex:1;padding:12px 16px;border:none;border-radius:var(--r-full);background:rgba(255,255,255,.9);font-size:14px;min-width:0}
.nl-btn{padding:12px 18px;background:var(--c-text);color:#fff;border-radius:var(--r-full);font-size:14px;font-weight:500;white-space:nowrap;transition:background var(--tr)}
.nl-btn:hover{background:#2C2420}

/* ============================================================
   PRODUCTS VIEW
   ============================================================ */
.pv-header{padding:22px 20px 14px;background:#fff;border-bottom:1px solid var(--c-border)}
.pv-title{font-size:22px;margin-bottom:14px}
.filter-bar{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;margin-bottom:2px}
.filter-bar::-webkit-scrollbar{display:none}
.filter-chip{flex-shrink:0;padding:7px 16px;background:var(--c-surface-2);border-radius:var(--r-full);font-size:13px;color:var(--c-text-2);cursor:pointer;transition:all var(--tr);white-space:nowrap;border:1.5px solid transparent}
.filter-chip.active{background:var(--c-text);color:#fff;border-color:var(--c-text)}
.sort-row{padding:10px 20px;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--c-muted)}
.sort-select{padding:5px 10px;border:1px solid var(--c-border);border-radius:var(--r-sm);background:#fff;font-size:12px;color:var(--c-text);cursor:pointer}
.products-list{padding:4px 20px 40px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.no-results{text-align:center;padding:60px 20px;color:var(--c-muted)}
.no-results .icon{font-size:48px;margin-bottom:14px}
.no-results h3{font-size:18px;margin-bottom:8px;color:var(--c-text-2)}

/* ============================================================
   PRODUCT DETAIL VIEW
   ============================================================ */
.detail-back{display:flex;align-items:center;gap:8px;padding:14px 20px;font-size:14px;color:var(--c-muted);cursor:pointer;transition:color var(--tr)}
.detail-back:hover{color:var(--c-text)}
.detail-back svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.detail-img{min-height:280px;display:flex;align-items:center;justify-content:center;font-size:100px;position:relative;overflow:hidden}
.detail-img-deco{position:absolute;inset:0;background:radial-gradient(circle at center,rgba(196,150,38,.08) 0%,transparent 65%)}
.detail-body{padding:24px 20px;background:#fff}
.detail-badges{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.detail-name{font-size:26px;font-weight:700;line-height:1.2;margin-bottom:5px}
.detail-name-en{font-size:13px;color:var(--c-muted);font-style:italic;margin-bottom:18px}
.detail-price-row{display:flex;align-items:baseline;gap:12px;margin-bottom:18px}
.detail-price{font-size:30px;font-weight:700;color:var(--c-orange)}
.detail-compare{font-size:16px;color:var(--c-muted);text-decoration:line-through}
.detail-disc{font-size:12px;font-weight:700;color:#fff;background:var(--c-orange);padding:2px 9px;border-radius:var(--r-full)}
.detail-benefits{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.detail-benefit-chip{padding:5px 12px;background:var(--c-gold-bg);border:1px solid rgba(196,150,38,.22);border-radius:var(--r-full);font-size:11px;color:var(--c-gold-d);font-weight:500}
.detail-stock{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;margin-bottom:18px}
.detail-stock.in{color:#16A34A}
.detail-stock.out{color:#EF4444}
.detail-stock::before{content:'';width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0}
.detail-qty{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.qty-label{font-size:13px;font-weight:500;color:var(--c-text-2)}
.qty-ctrl{display:flex;align-items:center;gap:12px}
.qty-btn{width:34px;height:34px;border:1.5px solid var(--c-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:all var(--tr);line-height:1}
.qty-btn:hover{border-color:var(--c-orange);color:var(--c-orange)}
.qty-val{font-size:16px;font-weight:600;min-width:24px;text-align:center}
.detail-cta{display:flex;gap:12px;margin-bottom:28px}
.detail-cta .btn{flex:1}
.detail-meta{font-size:12px;color:var(--c-muted);margin-bottom:28px}
.detail-meta span{font-weight:500;color:var(--c-text-2)}

/* Tabs */
.tabs-wrap{border-top:1px solid var(--c-border);padding-top:24px}
.tabs-header{display:flex;border-bottom:1px solid var(--c-border);margin-bottom:20px}
.tab-btn{flex:1;padding:12px 8px;font-size:13px;font-weight:500;color:var(--c-muted);border-bottom:2.5px solid transparent;transition:all var(--tr);text-align:center}
.tab-btn.active{color:var(--c-orange);border-bottom-color:var(--c-orange)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.tab-panel p{font-size:14px;color:var(--c-text-2);line-height:1.75}
.ingr-box{font-size:13px;color:var(--c-text-2);line-height:1.8;background:var(--c-surface-2);padding:16px;border-radius:var(--r-md)}
.howto-step{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;font-size:14px;color:var(--c-text-2)}
.howto-n{width:26px;height:26px;background:var(--c-orange);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}

/* Related */
.related{padding:36px 0 44px;background:var(--c-surface-2)}

/* ============================================================
   CART DRAWER
   ============================================================ */
.cart-drawer{position:fixed;bottom:0;left:0;right:0;z-index:400;max-height:82vh;background:#fff;border-radius:var(--r-xl) var(--r-xl) 0 0;transform:translateY(100%);transition:transform var(--tr-sl);box-shadow:0 -4px 40px rgba(0,0,0,.16)}
.cart-drawer.open{transform:translateY(0)}
.cart-handle{width:36px;height:4px;background:var(--c-border);border-radius:var(--r-full);margin:12px auto 0}
.cart-dh{padding:12px 20px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--c-border)}
.cart-dh h3{font-size:18px}
.cart-db{overflow-y:auto;max-height:calc(82vh - 200px);padding:12px 20px}
.cart-empty{text-align:center;padding:40px;color:var(--c-muted);font-size:14px}
.cart-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--c-border)}
.cart-item:last-child{border-bottom:none}
.ci-img{width:58px;height:58px;background:var(--c-surface-2);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:13px;font-weight:500;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-price{font-size:13px;color:var(--c-orange);font-weight:600}
.ci-ctrl{display:flex;align-items:center;gap:10px;flex-shrink:0}
.ci-qty-btn{width:28px;height:28px;border:1px solid var(--c-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;transition:all var(--tr)}
.ci-qty-btn:hover{border-color:var(--c-orange);color:var(--c-orange)}
.ci-qty{font-size:14px;font-weight:600;min-width:20px;text-align:center}
.cart-df{padding:14px 20px;border-top:1px solid var(--c-border)}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cart-total-l{font-size:15px;font-weight:500}
.cart-total-p{font-size:22px;font-weight:700;color:var(--c-orange)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--c-text);color:rgba(255,255,255,.65);padding:52px 20px 28px}
.footer-logo{font-family:var(--font-serif);font-size:22px;font-weight:700;color:#fff;letter-spacing:2.5px;margin-bottom:10px;display:flex;align-items:center;gap:5px}
.footer-logo .star{color:var(--c-gold)}
.footer-tagline{font-size:13px;margin-bottom:28px}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:32px}
.footer-col h4{color:#fff;font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:14px;font-family:var(--font-sans)}
.footer-link{display:block;font-size:13px;color:rgba(255,255,255,.5);padding:4px 0;transition:color var(--tr);cursor:pointer}
.footer-link:hover{color:var(--c-gold-l)}
.footer-socials{display:flex;gap:10px;margin-bottom:32px}
.social-btn{width:36px;height:36px;background:rgba(255,255,255,.08);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--tr);cursor:pointer}
.social-btn:hover{background:var(--c-gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.footer-copy{font-size:11px;color:rgba(255,255,255,.3)}
.footer-admin-link{font-size:11px;color:rgba(255,255,255,.25);cursor:pointer;transition:color var(--tr)}
.footer-admin-link:hover{color:var(--c-gold)}

/* ============================================================
   TOAST
   ============================================================ */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--c-text);color:#fff;padding:12px 22px;border-radius:var(--r-full);font-size:14px;font-weight:500;z-index:1000;transition:transform var(--tr-sl);white-space:nowrap;box-shadow:var(--sh-lg);pointer-events:none}
.toast.show{transform:translateX(-50%) translateY(0)}

/* Product card — arrow button (replaces add-to-cart) */
.pc-arrow-btn{width:32px;height:32px;background:var(--c-surface-2);color:var(--c-text-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all var(--tr);flex-shrink:0}
.product-card:hover .pc-arrow-btn{background:var(--c-orange);color:#fff}
.pc-discount-pill{position:absolute;top:10px;right:10px;z-index:2;background:var(--c-orange);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:var(--r-full)}

/* Contact strip on product detail */
.detail-contact-strip{background:var(--c-gold-bg);border:1px solid rgba(196,150,38,.2);border-radius:var(--r-lg);padding:16px;margin-bottom:20px}
.detail-contact-label{font-size:12px;font-weight:600;color:var(--c-gold-d);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.detail-contact-links{display:flex;flex-wrap:wrap;gap:8px}
.contact-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1.5px solid rgba(196,150,38,.3);border-radius:var(--r-full);font-size:13px;font-weight:500;color:var(--c-text-2);cursor:pointer;transition:all var(--tr)}
.contact-chip:hover{border-color:var(--c-gold);color:var(--c-gold-d);background:var(--c-gold-bg)}

/* Shimmer animation for skeleton */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .5s ease both}
.fade-up-1{animation-delay:.1s}.fade-up-2{animation-delay:.2s}.fade-up-3{animation-delay:.3s}

/* ============================================================
   ADMIN PANEL
   ============================================================ */
.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--c-bg);padding:20px}
.login-card{background:#fff;border-radius:var(--r-xl);padding:40px 32px;width:100%;max-width:380px;box-shadow:var(--sh-lg)}
.login-logo{font-family:var(--font-serif);font-size:24px;font-weight:700;letter-spacing:2px;text-align:center;margin-bottom:6px;color:var(--c-text)}
.login-logo .star{color:var(--c-gold)}
.login-sub{text-align:center;font-size:13px;color:var(--c-muted);margin-bottom:32px}
.login-form{display:flex;flex-direction:column;gap:16px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:13px;font-weight:500;color:var(--c-text-2)}
.form-input{padding:11px 14px;border:1.5px solid var(--c-border);border-radius:var(--r-md);font-size:14px;color:var(--c-text);transition:border-color var(--tr)}
.form-input:focus{border-color:var(--c-gold)}
.form-textarea{padding:11px 14px;border:1.5px solid var(--c-border);border-radius:var(--r-md);font-size:14px;color:var(--c-text);transition:border-color var(--tr);resize:vertical;min-height:90px}
.form-textarea:focus{border-color:var(--c-gold)}
.form-select{padding:11px 14px;border:1.5px solid var(--c-border);border-radius:var(--r-md);font-size:14px;color:var(--c-text);background:#fff;cursor:pointer;transition:border-color var(--tr)}
.form-select:focus{border-color:var(--c-gold)}
.form-error{font-size:12px;color:#EF4444}
.form-hint{font-size:12px;color:var(--c-muted)}
.form-check{display:flex;align-items:center;gap:10px;cursor:pointer}
.form-check input{width:16px;height:16px;accent-color:var(--c-orange)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.admin-app{display:none;min-height:100vh;background:var(--c-bg)}
.admin-app.active{display:flex;flex-direction:column}
.admin-topbar{height:56px;background:#fff;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:50}
.admin-topbar-logo{font-family:var(--font-serif);font-size:16px;font-weight:700;letter-spacing:1.5px;color:var(--c-text)}
.admin-topbar-logo .star{color:var(--c-gold)}
.admin-topbar-actions{display:flex;align-items:center;gap:8px}
.admin-layout{display:flex;flex:1;min-height:0}
.admin-sidebar{width:220px;background:#fff;border-right:1px solid var(--c-border);flex-shrink:0;overflow-y:auto;position:sticky;top:56px;max-height:calc(100vh - 56px)}
.admin-nav{padding:16px 0}
.admin-nav-item{display:flex;align-items:center;gap:10px;padding:12px 20px;font-size:14px;color:var(--c-text-2);cursor:pointer;transition:all var(--tr);border-left:3px solid transparent}
.admin-nav-item:hover{background:var(--c-surface-2);color:var(--c-text)}
.admin-nav-item.active{background:var(--c-orange-bg);color:var(--c-orange);border-left-color:var(--c-orange);font-weight:500}
.admin-nav-item .nav-icon{font-size:18px;width:22px;text-align:center}
.admin-content{flex:1;padding:24px;overflow-x:hidden}
.admin-section{display:none}
.admin-section.active{display:block}

/* Admin cards */
.admin-page-title{font-size:22px;font-weight:700;margin-bottom:4px;color:var(--c-text)}
.admin-page-sub{font-size:13px;color:var(--c-muted);margin-bottom:24px}
.stats-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:28px}
.stat-card{background:#fff;border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm)}
.stat-card-icon{font-size:28px;margin-bottom:10px}
.stat-card-n{font-size:28px;font-weight:700;color:var(--c-orange);line-height:1;margin-bottom:4px}
.stat-card-l{font-size:12px;color:var(--c-muted)}

/* Admin table */
.admin-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden}
.admin-card-header{padding:16px 20px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.admin-card-header h3{font-size:16px;font-weight:600}
.admin-search{padding:7px 14px;border:1.5px solid var(--c-border);border-radius:var(--r-full);font-size:13px;width:180px;transition:border-color var(--tr)}
.admin-search:focus{border-color:var(--c-gold)}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{padding:11px 14px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--c-muted);background:var(--c-surface-2);border-bottom:1px solid var(--c-border)}
td{padding:13px 14px;font-size:13px;color:var(--c-text-2);border-bottom:1px solid var(--c-border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--c-bg)}
.td-actions{display:flex;align-items:center;gap:8px}
.td-badge{display:inline-block;padding:2px 8px;border-radius:var(--r-full);font-size:11px;font-weight:600;background:var(--c-surface-2);color:var(--c-text-2)}
.td-badge.in{background:#DCFCE7;color:#16A34A}
.td-badge.out{background:#FEE2E2;color:#EF4444}
.td-emoji{font-size:24px;width:40px;height:40px;background:var(--c-surface-2);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}

/* Modal */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--tr)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:#fff;width:100%;max-width:600px;border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:92vh;overflow-y:auto;transform:translateY(100%);transition:transform var(--tr-sl)}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}
.modal-header h3{font-size:18px;font-weight:600}
.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);color:var(--c-muted);cursor:pointer;transition:all var(--tr)}
.modal-close:hover{background:var(--c-surface-2);color:var(--c-text)}
.modal-body{padding:24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--c-border);display:flex;gap:12px;justify-content:flex-end;position:sticky;bottom:0;background:#fff}

/* ============================================================
   RESPONSIVE — 640px+
   ============================================================ */
@media (min-width:640px){
  .products-grid,.products-list{grid-template-columns:repeat(3,1fr)}
  .hero-title{font-size:50px}
  .benefits-grid{grid-template-columns:repeat(4,1fr)}
  .stats-cards{grid-template-columns:repeat(4,1fr)}
}
@media (min-width:768px){
  :root{--nav-h:68px}
  .nav-logo{font-size:20px}
  .hero-content{padding:80px 40px 100px;max-width:620px}
  .modal{border-radius:var(--r-xl);margin:20px;max-height:calc(100vh - 40px)}
  .modal-overlay{align-items:center}
  .admin-sidebar{display:block!important}
}
@media (min-width:1024px){
  .products-grid,.products-list{grid-template-columns:repeat(4,1fr)}
  .hero-title{font-size:60px}
  .hero{min-height:100vh}
}
@media (max-width:767px){
  .admin-sidebar{display:none;position:fixed;top:56px;left:0;bottom:0;z-index:50;box-shadow:var(--sh-lg)}
  .admin-sidebar.open{display:block}
}

/* ── Image Upload ── */
.img-upload-wrap{border:2px dashed var(--c-border);border-radius:12px;padding:16px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:border-color var(--tr),background var(--tr);background:var(--c-surface-2)}
.img-upload-wrap:hover{border-color:var(--c-gold);background:rgba(201,169,110,.06)}
.img-upload-preview{width:80px;height:80px;border-radius:10px;background:var(--c-surface-3,#f0ede8);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.img-upload-label{font-size:13px;font-weight:500;color:var(--c-text);display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.img-upload-label svg{color:var(--c-gold)}
.img-upload-uploading{opacity:.6;pointer-events:none}

/* ── Product card image ── */
.pc-img img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.pc-img.has-image{font-size:0}

/* ── Detail page image ── */
.detail-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:1}
.detail-img.has-image{font-size:0;min-height:300px}

/* ══════════════════════════════════════
   PROMOTIONS
══════════════════════════════════════ */
.promos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;padding:0 0 8px}
.promo-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);display:flex;flex-direction:column;transition:transform var(--tr),box-shadow var(--tr)}
.promo-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.promo-img{height:200px;overflow:hidden}
.promo-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.promo-card:hover .promo-img img{transform:scale(1.04)}
.promo-img-empty{display:flex;align-items:center;justify-content:center}
.promo-body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.promo-badge{display:inline-block;color:#fff;font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;width:fit-content;letter-spacing:.5px}
.promo-title{font-family:var(--font-serif);font-size:17px;font-weight:700;color:var(--c-text);line-height:1.35;margin:0}
.promo-desc{font-size:13px;color:var(--c-muted);line-height:1.6;margin:0}
.promo-dates{font-size:12px;color:var(--c-muted);display:flex;gap:6px;align-items:center;margin-top:4px}
.promo-urgency{font-size:12px;font-weight:700;color:#e53e3e;background:#fff5f5;padding:6px 12px;border-radius:8px;margin-top:4px}

/* ══════════════════════════════════════
   ACTIVITIES
══════════════════════════════════════ */
.activities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;padding:0 0 8px}
.activity-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);display:flex;flex-direction:column;transition:transform var(--tr),box-shadow var(--tr);cursor:pointer}
.activity-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.activity-img{height:220px;overflow:hidden;background:var(--c-surface-2)}
.activity-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.activity-card:hover .activity-img img{transform:scale(1.04)}
.activity-img-empty{display:flex;align-items:center;justify-content:center}
.activity-body{padding:20px;display:flex;flex-direction:column;gap:6px}
.activity-date{font-size:12px;font-weight:600;color:var(--c-gold);letter-spacing:.3px}
.activity-title{font-family:var(--font-serif);font-size:17px;font-weight:700;color:var(--c-text);line-height:1.35;margin:0}
.activity-loc{font-size:12px;color:var(--c-muted)}
.activity-desc{font-size:13px;color:var(--c-muted);line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
/* Activity slider */
.act-slider{position:relative;height:220px;overflow:hidden;background:#111}
.act-slides{display:flex;height:100%;transition:transform .35s ease;will-change:transform}
.act-slide{min-width:100%;height:100%}
.act-slide img{width:100%;height:100%;object-fit:cover}
.act-slide-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);border:none;color:#fff;font-size:22px;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s;line-height:1}
.act-slide-btn:hover{background:rgba(0,0,0,.7)}
.act-prev{left:10px}
.act-next{right:10px}
.act-dots{position:absolute;bottom:8px;left:0;right:0;display:flex;justify-content:center;gap:5px;z-index:2}
.act-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;transition:background .2s,transform .2s}
.act-dot.active{background:#fff;transform:scale(1.3)}
/* Activity detail modal slider */
.ad-slider{position:relative;width:100%;background:#111;max-height:420px;overflow:hidden}
.ad-slides{display:flex;transition:transform .35s ease}
.ad-slide{min-width:100%}
.ad-slide img{width:100%;max-height:420px;object-fit:cover;display:block}

@media(max-width:600px){
  .promos-grid,.activities-grid{grid-template-columns:1fr}
}
