/* ===================== CSS VARIABLES (LIGHT THEME) ===================== */
:root {
  --outer-bg:   #F5F5F5;
  --bg:         #F9F9F9;
  --white:      #FFFFFF;
  --sidebar-bg: #FFFFFF;
  --card-bg:    #FFFFFF;
  --border:     #E5E7EB;
  --border2:    #D1D5DB;
  --primary:    #F97316;
  --primary-lt: #FFF7ED;
  --primary-md: #FED7AA;
  --text:       #111827;
  --text2:      #374151;
  --text3:      #6B7A9B;
  --text4:      #9DAABF;
  --text5:      #C5CEDF;
  --green:      #10C98A;
  --green-lt:   #E7FAF4;
  --red:        #F04438;
  --red-lt:     #FEF3F2;
  --amber:      #F79009;
  --amber-lt:   #FFFAEB;
  --shadow-sm:  0 1px 4px rgba(249,115,22,0.06), 0 2px 8px rgba(0,0,0,0.04);
  --shadow-md:  0 4px 16px rgba(249,115,22,0.08), 0 2px 8px rgba(0,0,0,0.06);
  --shadow-lg:  0 8px 32px rgba(249,115,22,0.12), 0 4px 16px rgba(0,0,0,0.08);
  --radius-sm:  8px;
  --radius:     12px;
  --radius-lg:  16px;
  --radius-xl:  20px;
  --sidebar-w:  240px;
  --font-d:     'Plus Jakarta Sans', sans-serif;
  --font-b:     'Outfit', sans-serif;
  --font-m:     'IBM Plex Mono', monospace;
  --trans:      all 0.2s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--outer-bg);color:var(--text);font-family:var(--font-b);font-size:14px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit}
ul,ol{list-style:none}
img{display:block;max-width:100%}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}

/* ===================== APP SHELL ===================== */
.app-outer{padding:0;min-height:100vh;display:flex;align-items:stretch}
.app-card{background:var(--white);border-radius:0;box-shadow:none;display:flex;width:100%;min-height:100vh;overflow:hidden}

/* ===================== SIDEBAR ===================== */
.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:relative;z-index:10}
.sidebar-logo{padding:14px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.logo-icon{width:40px;height:40px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 18px rgba(249,115,22,0.35)}
.logo-icon svg{width:18px;height:18px;color:#fff;fill:currentColor}
.logo-text h2{font-family:var(--font-d);font-size:14px;font-weight:800;color:var(--text);line-height:1.1}
.logo-text span{font-size:9px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--text3)}
.sidebar-body{padding:16px 12px;flex:1;overflow-y:auto}
.sidebar-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text4);padding:0 8px;margin-bottom:6px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-sm);color:var(--text3);font-size:13.5px;font-weight:500;cursor:pointer;transition:var(--trans);margin-bottom:2px;position:relative}
.nav-item svg{width:16px;height:16px;flex-shrink:0}
.nav-item:hover{background:var(--primary-lt);color:var(--primary)}
.nav-item.active{background:var(--primary);color:#fff}
.nav-item.active svg{stroke:#fff}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-m)}
.nav-divider{height:1px;background:var(--border);margin:12px 8px}
.sidebar-bottom{padding:12px;border-top:1px solid var(--border)}
.btn-admin-sidebar{width:100%;display:flex;align-items:center;gap:9px;padding:10px 12px;background:var(--amber-lt);border:1px solid #FDE68A;border-radius:var(--radius-sm);color:var(--amber);font-size:13px;font-weight:700;font-family:var(--font-d);cursor:pointer;transition:var(--trans)}
.btn-admin-sidebar:hover{background:#FFF3C4}
.btn-admin-sidebar svg{width:16px;height:16px}

/* ===================== MAIN ===================== */
.main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg)}

/* ===================== TOPBAR ===================== */
.topbar{height:64px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0;position:sticky;top:14px;margin:14px 18px 0;z-index:50}
.topbar-stat{display:flex;flex-direction:column}
.topbar-stat .big{font-family:var(--font-d);font-size:20px;font-weight:800;color:var(--text);line-height:1}
.topbar-stat .sm{font-size:11px;color:var(--text3);font-weight:400}
.topbar-toggle-group{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:3px;gap:2px;margin-left:20px}
.tg-btn{padding:6px 18px;border-radius:17px;font-size:13px;font-weight:500;color:var(--text3);cursor:pointer;transition:var(--trans)}
.tg-btn.active{background:var(--white);color:var(--text);box-shadow:var(--shadow-sm);font-weight:600}
.search-wrap{flex:1;max-width:380px;margin-left:auto;position:relative}
.search-input{width:100%;height:38px;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:0 16px 0 40px;color:var(--text);font-size:13px;transition:var(--trans)}
.search-input::placeholder{color:var(--text4)}
.search-input:focus{outline:none;border-color:var(--primary-md);background:var(--white);box-shadow:0 0 0 3px rgba(249,115,22,0.15)}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text4);pointer-events:none}
.search-icon svg{width:15px;height:15px}
.topbar-actions{display:flex;align-items:center;gap:6px}
.admin-header-dot{
  width:30px;
  height:30px;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--white);
  color:var(--text3);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:.46;
  transition:var(--trans);
}
.admin-header-dot svg{width:14px;height:14px}
.admin-header-dot:hover{
  opacity:.95;
  border-color:var(--primary-md);
  color:var(--primary);
  background:var(--primary-lt);
}
body.admin-open .admin-header-dot{
  opacity:0;
  pointer-events:none;
}
.icon-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text3);cursor:pointer;transition:var(--trans);position:relative}
.icon-btn:hover{background:var(--bg);color:var(--primary)}
.icon-btn svg{width:20px;height:20px}
.cart-badge{position:absolute;top:5px;right:5px;width:15px;height:15px;background:var(--red);color:#fff;font-size:8.5px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-m)}
.user-pill{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;background:var(--bg);border:1px solid var(--border);border-radius:20px;cursor:pointer;transition:var(--trans)}
.user-pill:hover{border-color:var(--primary-md)}
.user-avatar{width:30px;height:30px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;font-family:var(--font-d)}
.user-pill span{font-size:13px;font-weight:600;color:var(--text2)}

/* ===================== PAGE ===================== */
.page{padding:28px 30px 34px;flex:1;display:none}
#page-explore,#page-checkout{padding-top:32px}
.page.active{display:block}

/* ===================== EXPLORE / HOME ===================== */
.explore-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.explore-header h2{font-family:var(--font-d);font-size:22px;font-weight:800;color:var(--text)}
.cat-chips{display:flex;align-items:center;gap:6px}
.cat-chip{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--white);color:var(--text3);transition:var(--trans)}
.cat-chip svg{width:13px;height:13px}
.cat-chip:hover{border-color:var(--primary-md);color:var(--primary)}
.cat-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.filter-btn{display:flex;align-items:center;gap:7px;padding:7px 14px;border-radius:var(--radius-sm);background:var(--white);border:1px solid var(--border);color:var(--text3);font-size:13px;font-weight:500;cursor:pointer;transition:var(--trans)}
.filter-btn:hover{border-color:var(--primary-md);color:var(--primary)}
.filter-btn svg{width:15px;height:15px}

/* BuyMore-style explore grid */
.explore-grid{display:grid;grid-template-columns:1.4fr 0.8fr 0.8fr;grid-template-rows:auto auto;gap:14px}
.banner-card{background:linear-gradient(135deg,#F97316,#ea580c);border-radius:var(--radius-lg);padding:28px;grid-row:1/2;grid-column:1/2;position:relative;overflow:hidden;cursor:pointer;min-height:180px;display:flex;flex-direction:column;justify-content:flex-end}
.banner-card::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;background:rgba(255,255,255,0.08);border-radius:50%}
.banner-card::after{content:'';position:absolute;top:20px;right:60px;width:80px;height:80px;background:rgba(255,255,255,0.05);border-radius:50%}
.banner-card .tag{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:6px}
.banner-card h3{font-family:var(--font-d);font-size:22px;font-weight:800;color:#fff;line-height:1.2;margin-bottom:6px}
.banner-card p{font-size:13px;color:rgba(255,255,255,0.75);margin-bottom:16px}
.banner-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:rgba(255,255,255,0.95);border-radius:var(--radius-sm);font-size:13px;font-weight:700;color:var(--primary);cursor:pointer;transition:var(--trans);width:fit-content}
.banner-btn:hover{background:#fff;box-shadow:0 4px 12px rgba(0,0,0,0.15)}
.banner-card .pulse-dot{position:absolute;top:20px;left:20px;width:8px;height:8px;background:#10C98A;border-radius:50%;box-shadow:0 0 0 3px rgba(16,201,138,0.3)}

.promo-card{border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-end;min-height:160px}
.promo-card.yellow{background:#FFFBEB;border:1px solid #FDE68A}
.promo-card.green{background:#F0FDF4;border:1px solid #BBF7D0}
.promo-card .pc-tag{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text3);margin-bottom:4px}
.promo-card h4{font-family:var(--font-d);font-size:16px;font-weight:800;color:var(--text);line-height:1.2;margin-bottom:4px}
.promo-card p{font-size:12px;color:var(--text3)}
.promo-card .corner-btn{position:absolute;top:14px;right:14px;width:28px;height:28px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.promo-card .corner-btn svg{width:13px;height:13px;color:var(--text2)}

/* Product section */
.section-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;margin-top:28px}
.section-row h3{font-family:var(--font-d);font-size:17px;font-weight:800;color:var(--text)}
.see-all{font-size:13px;color:var(--text3);display:flex;align-items:center;gap:4px;cursor:pointer;transition:var(--trans)}
.see-all:hover{color:var(--primary)}
.see-all svg{width:13px;height:13px}

/* Product cards */
.products-scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.p-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:var(--trans)}
.p-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary-md)}
.p-card-img{aspect-ratio:1;background:var(--bg);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.p-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease}
.p-card:hover .p-card-img img{transform:scale(1.04)}
.p-card-img .icon-placeholder{color:var(--text5)}
.p-card-img .icon-placeholder svg{width:48px;height:48px}
.p-badge{position:absolute;top:10px;left:10px;font-size:9.5px;font-weight:700;padding:3px 9px;border-radius:12px;letter-spacing:.5px;text-transform:uppercase}
.p-badge.hot{background:var(--red-lt);color:var(--red)}
.p-badge.new{background:var(--primary-lt);color:var(--primary)}
.p-badge.sale{background:var(--amber-lt);color:var(--amber)}
.wish-btn{position:absolute;top:10px;right:10px;width:30px;height:30px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:var(--trans)}
.wish-btn:hover{transform:scale(1.1)}
.wish-btn.active svg{fill:var(--red);stroke:var(--red)}
.wish-btn svg{width:14px;height:14px;color:var(--text3)}
.p-card-body{padding:14px}
.p-card-brand{font-size:10.5px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text4);margin-bottom:3px}
.p-card-name{font-family:var(--font-d);font-size:13.5px;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:10px}
.p-card-tagline{font-size:11.5px;line-height:1.4;color:var(--text4);margin:-2px 0 8px}
.p-card-footer{display:flex;align-items:center;justify-content:space-between}
.p-card-price{font-family:var(--font-m);font-size:13px;font-weight:700;color:var(--text)}
.p-card-price-orig{font-family:var(--font-m);font-size:11px;color:var(--text4);text-decoration:line-through;margin-left:4px}
.p-card-add{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:var(--trans)}
.p-card-add:hover{background:#ea6c0a;transform:scale(1.05)}
.p-card-add svg{width:15px;height:15px;color:#fff}
.p-card-disc{font-size:10px;font-weight:700;color:var(--green);background:var(--green-lt);padding:2px 6px;border-radius:4px;margin-left:4px}

/* ===================== PRODUCT DETAIL ===================== */
.back-btn{display:inline-flex;align-items:center;gap:7px;color:var(--text3);font-size:13px;cursor:pointer;margin-bottom:24px;transition:var(--trans)}
.back-btn:hover{color:var(--primary)}
.back-btn svg{width:16px;height:16px}
.detail-layout{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.gallery-main-wrap{background:var(--bg);border-radius:var(--radius-lg);aspect-ratio:1;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:10px;border:1px solid var(--border)}
.gallery-main-wrap img{width:100%;height:100%;object-fit:cover}
.gallery-main-wrap .big-placeholder svg{width:100px;height:100px;color:var(--text5)}
.gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.g-thumb{aspect-ratio:1;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--trans)}
.g-thumb:hover,.g-thumb.active{border-color:var(--primary)}
.g-thumb img{width:100%;height:100%;object-fit:cover}
.g-thumb svg{width:22px;height:22px;color:var(--text5)}
.d-brand{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);margin-bottom:6px}
.d-name{font-family:var(--font-d);font-size:26px;font-weight:800;color:var(--text);line-height:1.15;margin-bottom:12px;letter-spacing:-0.3px}
.d-tagline{font-size:13px;line-height:1.6;color:var(--text3);margin:-6px 0 12px}
.d-price-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.d-price{font-family:var(--font-m);font-size:24px;font-weight:700;color:var(--text)}
.d-orig{font-family:var(--font-m);font-size:15px;color:var(--text4);text-decoration:line-through}
.d-disc{font-size:12px;font-weight:700;color:var(--green);background:var(--green-lt);padding:4px 9px;border-radius:5px}
.d-stock{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px;margin-bottom:16px}
.d-stock.in{background:var(--green-lt);color:var(--green)}
.d-stock.low{background:var(--amber-lt);color:var(--amber)}
.d-stock.out{background:var(--red-lt);color:var(--red)}
.d-stock .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.d-label{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text4);margin-bottom:10px}
.d-variants{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.v-btn{padding:7px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:var(--trans);background:var(--white)}
.v-btn:hover{border-color:var(--primary-md)}
.v-btn.active{border-color:var(--primary);background:var(--primary-lt);color:var(--primary);font-weight:600}
.v-btn.has-color{display:inline-flex;align-items:center;gap:8px}
.v-swatch{width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(15,23,42,0.28);background:var(--v-color,#cbd5e1);flex-shrink:0}
.d-qty-row{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;width:fit-content;margin-bottom:24px}
.d-qty-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--text2);cursor:pointer;transition:var(--trans)}
.d-qty-btn:hover{background:var(--primary-lt);color:var(--primary)}
.d-qty-val{width:44px;height:38px;display:flex;align-items:center;justify-content:center;font-family:var(--font-m);font-size:14px;font-weight:700;color:var(--text);background:var(--white);border-left:1.5px solid var(--border);border-right:1.5px solid var(--border)}
.d-actions{display:flex;gap:10px;margin-bottom:24px}
.btn-primary{flex:1;padding:13px 20px;background:var(--primary);border-radius:var(--radius-sm);color:#fff;font-family:var(--font-d);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:var(--trans)}
.btn-primary:hover{background:#ea6c0a;transform:translateY(-1px);box-shadow:0 4px 16px rgba(249,115,22,0.35)}
.btn-primary svg{width:17px;height:17px}
.btn-secondary{flex:1;padding:13px 20px;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);font-family:var(--font-d);font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:var(--trans)}
.btn-secondary:hover{border-color:var(--primary-md);color:var(--primary)}
.btn-secondary svg{width:17px;height:17px}
.btn-wa{padding:13px;background:#22C55E;border-radius:var(--radius-sm);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--trans)}
.btn-wa:hover{background:#16a34a;transform:translateY(-1px)}
.btn-wa svg{width:20px;height:20px}
.d-tabs{display:flex;border-bottom:1.5px solid var(--border);margin-bottom:16px;gap:0}
.d-tab{padding:10px 18px;font-size:13px;font-weight:500;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:var(--trans)}
.d-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
.d-tab-content{font-size:13.5px;color:var(--text2);line-height:1.8}
.d-highlights{margin:12px 0 0 18px;padding:0}
.d-highlights li{margin:0 0 5px;color:var(--text2)}
.specs-table{display:grid;gap:1px;background:var(--border);border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.spec-row{display:flex;background:var(--white)}
.spec-key{padding:9px 14px;font-size:12.5px;color:var(--text3);background:var(--bg);width:38%;border-right:1px solid var(--border);display:flex;align-items:center}
.spec-val{padding:9px 14px;font-size:13px;color:var(--text);font-weight:500;display:flex;align-items:center}

/* ===================== CHECKOUT TIMELINE ===================== */
.checkout-page{max-width:940px;margin:0 auto}
.checkout-timeline{display:flex;align-items:center;margin-bottom:44px;position:relative}
.checkout-timeline::before{content:'';position:absolute;top:18px;left:18px;right:18px;height:2px;background:var(--border);z-index:0}
.tl-progress{position:absolute;top:18px;left:18px;height:2px;background:var(--primary);z-index:1;transition:width 0.4s cubic-bezier(0.4,0,0.2,1)}
.tl-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}
.tl-dot{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;transition:var(--trans);font-family:var(--font-d)}
.tl-dot.done{background:var(--primary);border-color:var(--primary);color:#fff}
.tl-dot.done svg{width:16px;height:16px;stroke:#fff}
.tl-dot.current{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px var(--primary-lt)}
.tl-dot.current span{font-size:13px;font-weight:700;color:#fff}
.tl-dot span{font-size:13px;font-weight:600;color:var(--text3)}
.tl-label{font-size:11px;font-weight:600;color:var(--text3);text-align:center;letter-spacing:.3px}
.tl-label.active{color:var(--primary);font-weight:700}
.tl-label.done{color:var(--green);font-weight:600}

.checkout-body{display:grid;grid-template-columns:1fr 340px;gap:30px;align-items:start}
.ck-main{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.ck-main h3{font-family:var(--font-d);font-size:16px;font-weight:800;color:var(--text);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.ck-main h3 svg{width:18px;height:18px;color:var(--primary)}
.ck-sidebar{display:flex;flex-direction:column;gap:18px}
.ck-summary{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.ck-summary h4{font-family:var(--font-d);font-size:13.5px;font-weight:800;color:var(--text);margin-bottom:14px}
.ck-item{display:flex;align-items:center;gap:11px;padding:8px 0;border-bottom:1px solid var(--border)}
.ck-item:last-of-type{border-bottom:none}
.ck-item-img{width:44px;height:44px;background:var(--bg);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border:1px solid var(--border)}
.ck-item-img img{width:100%;height:100%;object-fit:cover}
.ck-item-img svg{width:20px;height:20px;color:var(--text5)}
.ck-item-info{flex:1;min-width:0}
.ck-item-name{font-size:12.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ck-item-meta{font-size:11px;color:var(--text3)}
.ck-item-price{font-family:var(--font-m);font-size:13px;font-weight:700;color:var(--text);white-space:nowrap}
.ck-totals{margin-top:14px}
.ck-tot-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text3);padding:4px 0}
.ck-tot-row.grand{font-family:var(--font-d);font-size:15px;font-weight:800;color:var(--text);border-top:1.5px solid var(--border);margin-top:8px;padding-top:12px}
.ck-tot-row.grand .ck-amount{color:var(--primary);font-family:var(--font-m)}
.ck-help-box{margin-top:14px;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}
.ck-help-box h5{font-family:var(--font-d);font-size:12px;font-weight:800;color:var(--text);margin-bottom:4px}
.ck-help-box p{font-size:11.5px;line-height:1.45;color:var(--text3);margin-bottom:10px}
.ck-help-btn{padding:10px 12px;font-size:12.5px}

/* Form elements */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:11.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);margin-bottom:7px}
.form-label .req{color:var(--red)}
.form-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-size:13.5px;transition:var(--trans)}
.form-input::placeholder{color:var(--text4)}
.form-input:focus{outline:none;border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px rgba(249,115,22,0.15)}
.form-select{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-size:13.5px;cursor:pointer;appearance:none;transition:var(--trans)}
.form-select:focus{outline:none;border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px rgba(249,115,22,0.15)}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-textarea{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-size:13.5px;min-height:80px;resize:vertical;transition:var(--trans)}
.form-textarea:focus{outline:none;border-color:var(--primary);background:var(--white)}

/* Payment method cards */
.pay-methods{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.pay-option{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--trans)}
.pay-option:hover{border-color:var(--primary-md)}
.pay-option.selected{background:var(--primary-lt);border-color:var(--primary)}
.pay-radio{width:18px;height:18px;border:2px solid var(--border2);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:var(--trans)}
.pay-option.selected .pay-radio{border-color:var(--primary)}
.pay-option.selected .pay-radio::after{content:'';width:8px;height:8px;background:var(--primary);border-radius:50%}
.pay-option.wa-opt.selected{background:#F0FDF4;border-color:#22C55E}
.pay-option.wa-opt.selected .pay-radio{border-color:#22C55E}
.pay-option.wa-opt.selected .pay-radio::after{background:#22C55E}
.pay-icon{width:40px;height:40px;background:var(--bg);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border)}
.pay-icon svg{width:22px;height:22px}
.pay-info h4{font-family:var(--font-d);font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:2px}
.pay-info p{font-size:12px;color:var(--text3)}

/* CTA buttons */
.btn-cta{width:100%;padding:14px;border-radius:var(--radius-sm);font-family:var(--font-d);font-size:14.5px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:var(--trans)}
.btn-cta.blue{background:var(--primary);color:#fff;border:none}
.btn-cta.blue:hover{background:#ea6c0a;box-shadow:0 4px 16px rgba(249,115,22,0.35)}
.btn-cta.green{background:#22C55E;color:#fff;border:none}
.btn-cta.green:hover{background:#16a34a}
.btn-cta.outline{background:var(--white);color:var(--text2);border:1.5px solid var(--border)}
.btn-cta.outline:hover{border-color:var(--primary-md);color:var(--primary)}
.btn-cta svg{width:17px;height:17px}

/* Checkout nav */
.ck-nav-row{display:flex;justify-content:space-between;align-items:center;margin-top:30px;padding-top:24px;border-top:1.5px solid var(--border)}

/* ===================== ORDER SUCCESS ===================== */
.success-page{max-width:520px;margin:40px auto;text-align:center}
.success-icon{width:72px;height:72px;background:var(--green-lt);border:1.5px solid #BBF7D0;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.success-icon svg{width:32px;height:32px;color:var(--green)}
.success-page h2{font-family:var(--font-d);font-size:28px;font-weight:800;color:var(--text);margin-bottom:8px}
.success-page>p{font-size:14px;color:var(--text3);margin-bottom:28px;line-height:1.7}
.order-detail-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:left;margin-bottom:20px}
.odc-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text3);padding:6px 0;border-bottom:1px solid var(--border)}
.odc-row:last-child{border-bottom:none}
.odc-row strong{color:var(--text);font-weight:600}
.odc-order-num{font-family:var(--font-m);font-size:13px;font-weight:700;color:var(--primary);margin-bottom:14px;display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--primary-lt);border-radius:var(--radius-sm)}

/* ===================== CART DRAWER ===================== */
.overlay{position:fixed;inset:0;background:rgba(17,24,39,0.42);backdrop-filter:blur(4px);z-index:200;opacity:0;pointer-events:none;transition:opacity 0.25s}
.overlay.open{opacity:1;pointer-events:all}
.cart-drawer{position:fixed;top:0;right:0;width:410px;max-width:100vw;height:100vh;background:var(--white);border-left:1px solid var(--border);box-shadow:0 14px 44px rgba(15,23,42,0.2);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1)}
.cart-drawer.open{transform:translateX(0)}
.cd-header{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;background:linear-gradient(180deg,#FFF7ED 0%, #fff 80%)}
.cd-head-main{display:flex;flex-direction:column;gap:4px}
.cd-header h3{font-family:var(--font-d);font-size:18px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:9px}
.cd-header h3 span{font-size:12px;font-weight:700;color:var(--primary);background:var(--white);border:1px solid var(--primary-md);padding:2px 9px;border-radius:999px;font-family:var(--font-m)}
.cd-head-sub{font-size:12px;color:var(--text3)}
.cd-close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);color:var(--text3);cursor:pointer;transition:var(--trans);background:var(--white)}
.cd-close:hover{background:var(--bg);color:var(--text);border-color:var(--primary-md)}
.cd-close svg{width:17px;height:17px}
.cd-items{flex:1;overflow-y:auto;padding:14px 14px 20px;background:var(--bg)}
.cd-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:60px 22px;text-align:center}
.cd-empty svg{width:52px;height:52px;color:var(--text5)}
.cd-empty h4{font-family:var(--font-d);font-size:17px;font-weight:700;color:var(--text2);margin-top:2px}
.cd-empty p{font-size:13px;color:var(--text3);line-height:1.5;max-width:220px}
.cd-empty .btn-cta{margin-top:4px}
.cd-item{display:flex;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--white);margin-bottom:10px}
.cd-item:last-child{margin-bottom:0}
.cd-item-img{width:64px;height:64px;background:var(--bg);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border:1px solid var(--border)}
.cd-item-img img{width:100%;height:100%;object-fit:cover}
.cd-item-img svg{width:26px;height:26px;color:var(--text5)}
.cd-item-info{flex:1;min-width:0}
.cd-item-name{font-size:13.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.cd-item-variant{font-size:11.5px;color:var(--text3);margin-bottom:9px}
.cd-item-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text4);margin-top:8px}
.cd-line-total{font-family:var(--font-m);font-size:12px;font-weight:700;color:var(--text2)}
.cd-qty-row{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;width:fit-content;background:var(--white)}
.cq-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--text2);cursor:pointer;transition:var(--trans)}
.cq-btn:hover{background:var(--primary-lt);color:var(--primary)}
.cq-val{width:33px;height:28px;display:flex;align-items:center;justify-content:center;font-family:var(--font-m);font-size:12px;font-weight:700;color:var(--text);background:var(--white);border-left:1px solid var(--border);border-right:1px solid var(--border)}
.cd-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.cd-item-price{font-family:var(--font-m);font-size:13px;font-weight:800;color:var(--text)}
.cd-remove{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:7px;color:var(--text4);cursor:pointer;transition:var(--trans);background:var(--bg)}
.cd-remove:hover{background:var(--red-lt);color:var(--red)}
.cd-remove svg{width:13px;height:13px}
.ck-review-item-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;min-width:88px}
.ck-remove-btn{border:1px solid #fecaca;background:#fff1f2;color:#b91c1c;font-size:11.5px;font-weight:600;padding:5px 10px;border-radius:8px;cursor:pointer;transition:var(--trans)}
.ck-remove-btn:hover{background:#ffe4e6;border-color:#fda4af}
.cd-footer{padding:14px 14px 16px;border-top:1px solid var(--border);background:var(--white)}
.cd-summary-card{border:1px solid var(--border);border-radius:12px;background:var(--bg);padding:10px 12px;margin-bottom:10px}
.cd-total-row{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--text3);padding:4px 0}
.cd-total-row.grand{font-family:var(--font-d);font-size:16px;font-weight:800;color:var(--text);margin-top:3px;padding-top:8px;border-top:1px dashed var(--border)}
.cd-total-row.grand .g-amount{color:var(--primary);font-family:var(--font-m)}
.cd-checkout-btn{margin-bottom:8px}
.cd-continue-btn{width:100%;padding:11px 14px}

/* ===================== ADMIN PANEL ===================== */
.admin-overlay{position:fixed;inset:0;background:rgba(17,24,39,0.5);backdrop-filter:blur(8px);z-index:500;display:none}
.admin-overlay.open{display:flex;flex-direction:column;overflow:hidden;overscroll-behavior:contain;align-items:stretch;justify-content:flex-start}
.admin-shell{background:var(--white);margin:0;border-radius:0;flex:1;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);width:100%;height:100dvh;max-height:100dvh;min-height:100dvh}
.admin-topbar{height:56px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:20px;flex-shrink:0;position:sticky;top:0;z-index:5}
.admin-topbar-left{display:flex;align-items:center;gap:16px}
.admin-topbar-left h3{font-family:var(--font-d);font-size:15px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px}
.admin-badge{font-size:9.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;background:var(--amber-lt);color:var(--amber);border:1px solid #FDE68A;padding:3px 8px;border-radius:10px}
.admin-tabs{display:flex;gap:3px;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:3px}
.admin-tab{padding:6px 14px;border-radius:17px;font-size:12.5px;font-weight:500;color:var(--text3);cursor:pointer;transition:var(--trans)}
.admin-tab:hover{color:var(--text2)}
.admin-tab.active{background:var(--white);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}
.admin-catalog-switch{display:flex;align-items:center;gap:4px;background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:3px}
.admin-catalog-btn{padding:6px 11px;border-radius:999px;border:none;background:transparent;color:var(--text3);font-size:11.5px;font-weight:700;letter-spacing:.2px;cursor:pointer;transition:var(--trans)}
.admin-catalog-btn:hover{color:var(--text2)}
.admin-catalog-btn.active{background:var(--white);color:var(--primary);box-shadow:var(--shadow-sm)}
.admin-close{margin-left:auto;display:flex;align-items:center;gap:7px;padding:8px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:var(--trans)}
.admin-close:hover{border-color:var(--red);color:var(--red)}
.admin-close svg{width:14px;height:14px}
.admin-body{flex:1;min-height:0;height:100%;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;scrollbar-gutter:stable;padding:24px 24px 44px}
#adminDashScreen,#adminProducts,#adminOrders,#adminSettings{min-height:0}
#prodFormWrap{scroll-margin-top:12px}
.admin-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.a-stat{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}
.a-stat.accent{background:var(--primary-lt);border-color:var(--primary-md)}
.a-stat .asl{font-size:10.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text3);margin-bottom:8px}
.a-stat.accent .asl{color:var(--primary)}
.a-stat .asv{font-family:var(--font-d);font-size:24px;font-weight:800;color:var(--text)}
.a-stat.accent .asv{color:var(--primary)}
.a-stat .ass{font-size:12px;color:var(--text3)}
.table-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px}
.table-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.table-header h4{font-family:var(--font-d);font-size:14.5px;font-weight:800;color:var(--text)}
.admin-scope-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg);font-size:11px;font-weight:700;color:var(--text3)}
.btn-add{display:flex;align-items:center;gap:7px;padding:8px 16px;background:var(--primary);border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--font-d);font-size:13px;font-weight:700;cursor:pointer;transition:var(--trans)}
.btn-add:hover{background:#ea6c0a}
.btn-add svg{width:14px;height:14px}
table{width:100%;border-collapse:collapse}
thead tr{border-bottom:1px solid var(--border);background:var(--bg)}
thead th{padding:10px 14px;text-align:left;font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text3)}
tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--bg)}
tbody td{padding:11px 14px;font-size:13px;color:var(--text2);vertical-align:middle}
.td-prod{display:flex;align-items:center;gap:10px}
.td-thumb{width:38px;height:38px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.td-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.td-thumb svg{width:16px;height:16px;color:var(--text4)}
.td-name{font-weight:600;color:var(--text);font-size:13px}
.td-sub{font-size:11.5px;color:var(--text3)}
.pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px}
.pill.active{background:var(--green-lt);color:var(--green)}
.pill.inactive{background:var(--red-lt);color:var(--red)}
.pill.pending{background:var(--amber-lt);color:var(--amber)}
.pill.paid{background:var(--green-lt);color:var(--green)}
.pill.shipped{background:var(--primary-lt);color:var(--primary)}
.tbl-btns{display:flex;align-items:center;gap:5px}
.tbl-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text4);cursor:pointer;transition:var(--trans);background:transparent}
.tbl-btn:hover{background:var(--bg);color:var(--text2)}
.tbl-btn.del:hover{background:var(--red-lt);color:var(--red)}
.tbl-btn svg{width:14px;height:14px}
.prod-form{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}
.prod-form h4{font-family:var(--font-d);font-size:15px;font-weight:800;color:var(--text);margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ===================== ADMIN LOGIN ===================== */
.admin-login{display:flex;align-items:center;justify-content:center;flex:1;padding:40px}
.al-box{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;max-width:380px;width:100%;text-align:center}
.al-icon{width:56px;height:56px;background:var(--amber-lt);border:1.5px solid #FDE68A;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.al-icon svg{width:26px;height:26px;color:var(--amber)}
.al-box h3{font-family:var(--font-d);font-size:21px;font-weight:800;color:var(--text);margin-bottom:5px}
.al-box p{font-size:13px;color:var(--text3);margin-bottom:24px}
.error-box{background:var(--red-lt);border:1px solid #FECDD3;color:var(--red);font-size:13px;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:14px;display:none}
.error-box.show{display:block}

/* ===================== TOAST ===================== */
.toast-wrap{position:fixed;bottom:22px;right:22px;z-index:999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:13px 16px;display:flex;align-items:center;gap:11px;min-width:270px;box-shadow:var(--shadow-lg);animation:slideUp 0.25s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.t-icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.t-icon.ok{background:var(--green-lt);color:var(--green)}
.t-icon.err{background:var(--red-lt);color:var(--red)}
.t-icon.inf{background:var(--primary-lt);color:var(--primary)}
.t-icon svg{width:14px;height:14px}
.t-text strong{font-size:13px;font-weight:600;color:var(--text)}
.t-text p{font-size:12px;color:var(--text3)}

/* ===================== INSTALL PROMPT ===================== */
.install-prompt{
  position:fixed;
  right:20px;
  bottom:20px;
  width:min(360px,calc(100vw - 24px));
  background:var(--white);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:var(--shadow-lg);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:10px 12px;
  padding:14px 14px 12px;
  z-index:998;
  opacity:0;
  transform:translateY(14px);
  pointer-events:none;
  transition:opacity .22s ease, transform .22s ease;
}
.install-prompt.show{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.ip-close{
  position:absolute;
  top:8px;
  right:8px;
  width:26px;
  height:26px;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--bg);
  color:var(--text3);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:var(--trans);
}
.ip-close:hover{
  border-color:var(--primary-md);
  color:var(--primary);
  background:var(--primary-lt);
}
.ip-close svg{width:12px;height:12px}
.ip-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  background:var(--primary-lt);
  border:1px solid var(--primary-md);
  display:flex;
  align-items:center;
  justify-content:center;
}
.ip-icon img{width:24px;height:24px}
.ip-copy strong{
  display:block;
  font-family:var(--font-d);
  font-size:14px;
  font-weight:800;
  color:var(--text);
  line-height:1.2;
  padding-right:22px;
}
.ip-copy p{
  margin-top:4px;
  font-size:12px;
  color:var(--text3);
  line-height:1.5;
}
.ip-actions{
  grid-column:1 / -1;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  margin-top:2px;
}
.ip-btn{
  height:34px;
  border-radius:10px;
  padding:0 12px;
  font-size:12px;
  font-weight:700;
  border:1px solid var(--border);
  transition:var(--trans);
}
.ip-btn-primary{
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
}
.ip-btn-primary:hover{background:#ea6c0a}
.ip-btn-ghost{
  background:var(--white);
  color:var(--text2);
}
.ip-btn-ghost:hover{
  border-color:var(--primary-md);
  color:var(--primary);
  background:var(--primary-lt);
}

/* ===================== MISC ===================== */
.tag-chip{display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;border-radius:5px;background:var(--bg);color:var(--text3)}
.loader{display:flex;align-items:center;justify-content:center;padding:60px;gap:12px;color:var(--text3);font-size:13px}
.spinner{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.p-card-skeleton{pointer-events:none}
.p-card-skeleton .p-card-gradient,
.p-card-skeleton .wish-btn,
.p-card-skeleton .p-badge{display:none!important}
.p-card-skeleton .p-card-img{position:relative;overflow:hidden}
.p-card-skeleton .p-card-body{z-index:2}
.sk{position:relative;overflow:hidden;background:#e6e8ef;border-radius:10px}
.sk::after{
  content:'';
  position:absolute;
  inset:0;
  transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);
  animation:skShimmer 1.2s infinite;
}
.sk-media{position:absolute;inset:0;border-radius:0}
.sk-line{height:12px;margin-bottom:8px}
.sk-brand{width:36%;height:10px}
.sk-name{width:78%;height:18px}
.sk-tag{width:64%;height:11px;margin-bottom:12px}
.sk-price{width:46%;height:15px;margin-bottom:0}
.sk-btn{width:42px;height:42px;border-radius:999px;background:#d8dce6}
@keyframes skShimmer{100%{transform:translateX(100%)}}
[data-theme="dark"] .sk{background:#2b313c}
[data-theme="dark"] .sk-btn{background:#3a4251}
[data-theme="dark"] .sk::after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.16),transparent)}
.empty-state{text-align:center;padding:60px 40px}
.empty-state svg{width:52px;height:52px;color:var(--text5);margin:0 auto 16px}
.empty-state h3{font-family:var(--font-d);font-size:18px;font-weight:700;color:var(--text2);margin-bottom:6px}
.empty-state p{font-size:13px;color:var(--text3)}
.mob-toggle{display:none;width:38px;height:38px;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);cursor:pointer;margin-right:8px;flex-shrink:0}
.mob-overlay{display:none;position:fixed;inset:0;background:rgba(17,24,39,.4);z-index:9}

@media(max-width:900px){
  body.mobile-sidebar-open{
    overflow:hidden;
  }
  .app-outer{padding:0}
  .app-card{border-radius:0;min-height:100vh}
  .sidebar{position:fixed;top:0;left:0;height:100vh;z-index:100;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .topbar{top:10px;margin:10px 12px 0;padding:0 14px;height:60px;border-radius:var(--radius)}
  .mob-toggle{display:inline-flex !important;width:40px;height:40px;background:var(--white);border-color:var(--border2);color:var(--text2);box-shadow:0 1px 4px rgba(17,24,39,.08)}
  .topbar-stat .sm{display:none}
  .topbar-actions{margin-left:auto}
  .topbar-toggle-group{display:none}
  .mob-overlay.show{display:block}
  .detail-layout{grid-template-columns:1fr}
  .explore-grid{grid-template-columns:1fr}
  .checkout-body{grid-template-columns:1fr;gap:18px}
  .admin-stats-row{grid-template-columns:1fr 1fr}
  .admin-topbar{height:auto;min-height:calc(56px + env(safe-area-inset-top));padding:calc(10px + env(safe-area-inset-top)) 14px 10px;align-items:flex-start}
  .admin-topbar-left{flex-wrap:wrap;gap:10px}
  .admin-catalog-switch{width:100%;justify-content:flex-start}
  .form-grid-3{grid-template-columns:1fr 1fr}
  .admin-shell{margin:0;height:100dvh;max-height:100dvh;border-radius:0}
  .admin-body{padding:16px 14px 30px}
  .page{padding:22px 16px 24px}
  #page-explore,#page-checkout{padding-top:20px}
  .install-prompt{
    left:12px;
    right:12px;
    bottom:12px;
    width:auto;
    border-radius:14px;
  }
}
@media(max-width:600px){
  .admin-stats-row{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
  .cat-chips{overflow-x:auto}
  .d-actions{flex-direction:column}
  .form-grid-3{grid-template-columns:1fr}
}

/* ===================== DARK THEME ===================== */
[data-theme="dark"] {
  --outer-bg:   #0a0a0a;
  --bg:         #111111;
  --white:      #1a1a1a;
  --sidebar-bg: #141414;
  --card-bg:    #1a1a1a;
  --border:     #2a2a2a;
  --border2:    #333333;
  --primary:    #FF6B1A;
  --primary-lt: rgba(255,107,26,0.12);
  --primary-md: rgba(255,107,26,0.25);
  --text:       #F0F0F0;
  --text2:      #C0C0C0;
  --text3:      #888888;
  --text4:      #555555;
  --text5:      #333333;
  --green:      #10C98A;
  --green-lt:   rgba(16,201,138,0.12);
  --red:        #F04438;
  --red-lt:     rgba(240,68,56,0.12);
  --amber:      #F79009;
  --amber-lt:   rgba(247,144,9,0.12);
  --shadow-sm:  0 1px 4px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.3);
  --shadow-md:  0 4px 16px rgba(0,0,0,0.5), 0 2px 8px rgba(0,0,0,0.4);
  --shadow-lg:  0 8px 32px rgba(0,0,0,0.6), 0 4px 16px rgba(0,0,0,0.5);
}

/* ===================== GLASS / REFLECTIVE SURFACES ===================== */
.glass {
  background: rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255,255,255,0.1) !important;
}
[data-theme="dark"] .glass {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
}
.glass-card {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(20px) saturate(200%);
  -webkit-backdrop-filter: blur(20px) saturate(200%);
  border: 1px solid rgba(255,255,255,0.6);
  box-shadow: 0 8px 32px rgba(249,115,22,0.08), 0 2px 8px rgba(0,0,0,0.04), inset 0 1px 0 rgba(255,255,255,0.9);
}
[data-theme="dark"] .glass-card {
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.06);
}

/* Reflective shimmer on cards */
.p-card::after, .a-stat::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 40%;
  background: linear-gradient(180deg, rgba(255,255,255,0.08) 0%, transparent 100%);
  border-radius: inherit;
  pointer-events: none;
}
.p-card { position: relative; overflow: hidden; }
.a-stat { position: relative; overflow: hidden; }

/* ===================== THEME SWITCHER ===================== */
.theme-switcher {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: var(--trans);
  margin: 0 0 6px;
  background: var(--bg);
  border: 1px solid var(--border);
}
.theme-switcher:hover { border-color: var(--primary-md); }
.ts-track {
  width: 40px; height: 22px;
  background: var(--border2);
  border-radius: 11px;
  position: relative;
  transition: background 0.3s;
  flex-shrink: 0;
}
.ts-track.on { background: var(--primary); }
.ts-thumb {
  width: 16px; height: 16px;
  background: #fff;
  border-radius: 50%;
  position: absolute;
  top: 3px; left: 3px;
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}
.ts-track.on .ts-thumb { transform: translateX(18px); }
.ts-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text3);
  flex-shrink: 0;
}
.ts-icon svg {
  width: 15px;
  height: 15px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
[data-theme="dark"] .ts-icon { color: #f59e0b; }
.ts-label { font-size: 12.5px; font-weight: 600; color: var(--text3); flex: 1; }

/* ===================== HERO BANNER UPGRADES ===================== */
.hero-banner-img {
  width: 100%;
  aspect-ratio: 16/7;
  background: linear-gradient(135deg, #F97316, #ea580c);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  cursor: pointer;
  transition: var(--trans);
}
.hero-banner-img:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.hero-banner-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.hero-banner-img:hover img { transform: scale(1.03); }
.hero-banner-img .hb-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,0.55) 0%, transparent 60%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 24px;
}
.hero-banner-img .hb-tag {
  font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: rgba(255,255,255,0.7); margin-bottom: 6px;
}
.hero-banner-img .hb-title {
  font-family: var(--font-d); font-size: 24px; font-weight: 800;
  color: #fff; line-height: 1.2; margin-bottom: 8px;
}
.hero-banner-img .hb-sub { font-size: 13px; color: rgba(255,255,255,0.8); margin-bottom: 14px; }
.hero-banner-img .hb-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 18px; background: rgba(255,255,255,0.92);
  border-radius: var(--radius-sm); font-size: 12px; font-weight: 700;
  color: #111; width: fit-content; transition: var(--trans);
}
.hero-banner-img .hb-btn:hover { background: #fff; }
.hero-pulse { position: absolute; top: 16px; left: 16px; width: 8px; height: 8px;
  background: #10C98A; border-radius: 50%; box-shadow: 0 0 0 3px rgba(16,201,138,0.3); }

/* promo cards with image */
.promo-img-card {
  border-radius: var(--radius-lg); overflow: hidden; position: relative;
  cursor: pointer; min-height: 150px; transition: var(--trans);
}
.promo-img-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.promo-img-card img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 0.4s ease;
}
.promo-img-card:hover img { transform: scale(1.04); }
.promo-img-card .pic-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,0.6) 0%, transparent 50%);
  padding: 16px; display: flex; flex-direction: column; justify-content: flex-end;
}
.promo-img-card .pic-title {
  font-family: var(--font-d); font-size: 16px; font-weight: 800; color: #fff;
  margin-bottom: 2px;
}
.promo-img-card .pic-sub { font-size: 12px; color: rgba(255,255,255,0.75); }
.promo-img-card .pic-corner {
  position: absolute; top: 12px; right: 12px; width: 28px; height: 28px;
  background: rgba(255,255,255,0.9); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.promo-img-card .pic-corner svg { width: 13px; height: 13px; }

/* Product card image upgrade */
.p-card-img-hero {
  aspect-ratio: 1; background: var(--bg); overflow: hidden; position: relative;
}
.p-card-img-hero img {
  width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease;
}
.p-card:hover .p-card-img-hero img { transform: scale(1.06); }

/* ===================== ADMIN EXTREME UPGRADES ===================== */
.admin-overlay.legacy-admin-theme { background: rgba(0,0,0,0.7) !important; }
[data-theme="dark"] .admin-shell {
  background: #141414;
  border: 1px solid rgba(255,255,255,0.08);
}

/* Admin sidebar layout */
.admin-shell-inner {
  display: flex; flex: 1; overflow: hidden;
}
.admin-sidebar-nav {
  width: 200px; background: var(--bg); border-right: 1px solid var(--border);
  flex-shrink: 0; display: flex; flex-direction: column; padding: 16px 0;
  overflow-y: auto;
}
.admin-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 20px; color: var(--text3); font-size: 13px; font-weight: 500;
  cursor: pointer; transition: var(--trans); border-left: 3px solid transparent;
}
.admin-nav-item svg { width: 15px; height: 15px; flex-shrink: 0; }
.admin-nav-item:hover { background: var(--primary-lt); color: var(--primary); border-left-color: var(--primary-md); }
.admin-nav-item.active { background: var(--primary-lt); color: var(--primary); border-left-color: var(--primary); font-weight: 700; }

.admin-content { flex: 1; overflow-y: auto; }
.admin-section { display: none; padding: 24px; }
.admin-section.active { display: block; }

/* Admin section headers */
.admin-sec-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border);
}
.admin-sec-header h3 {
  font-family: var(--font-d); font-size: 18px; font-weight: 800; color: var(--text);
  display: flex; align-items: center; gap: 10px;
}
.admin-sec-header h3 svg { width: 20px; height: 20px; color: var(--primary); }

/* Image upload zone */
.img-upload-zone {
  border: 2px dashed var(--border2); border-radius: var(--radius-lg);
  padding: 28px 20px; text-align: center; cursor: pointer;
  transition: var(--trans); background: var(--bg); position: relative;
  overflow: hidden;
}
.img-upload-zone:hover { border-color: var(--primary); background: var(--primary-lt); }
.img-upload-zone .iuz-icon {
  width: 44px; height: 44px; background: var(--primary-lt); border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 12px; color: var(--primary);
}
.img-upload-zone .iuz-icon svg { width: 22px; height: 22px; }
.img-upload-zone p { font-size: 13px; color: var(--text3); margin-bottom: 4px; }
.img-upload-zone span { font-size: 11px; color: var(--text4); }
.img-url-preview {
  margin-top: 12px; border: 1px solid var(--border); border-radius: var(--radius-sm);
  overflow: hidden; aspect-ratio: 16/9; background: var(--bg); position: relative;
}
.img-url-preview img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.img-url-preview .ipv-placeholder {
  position: absolute; inset: 0; display: flex; align-items: center;
  justify-content: center; color: var(--text5);
}
.img-url-preview .ipv-placeholder svg { width: 40px; height: 40px; }
.img-url-row {
  display: flex; gap: 8px; margin-top: 8px; align-items: center;
}
.img-url-row input { flex: 1; }
.img-url-row .iur-apply {
  padding: 10px 16px; background: var(--primary); color: #fff;
  border-radius: var(--radius-sm); font-size: 12.5px; font-weight: 700;
  cursor: pointer; transition: var(--trans); white-space: nowrap; flex-shrink: 0;
}
.img-url-row .iur-apply:hover { background: #ea6c0a; }

/* Banner image manager */
.banner-manager {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px;
}
.banner-slot {
  border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden;
  background: var(--white); transition: var(--trans);
}
.banner-slot:hover { box-shadow: var(--shadow-md); }
.bs-preview {
  aspect-ratio: 16/7; background: var(--bg); position: relative; overflow: hidden;
}
.bs-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bs-preview .bsp-placeholder {
  position: absolute; inset: 0; display: flex; align-items: center;
  justify-content: center; flex-direction: column; gap: 8px; color: var(--text5);
}
.bs-preview .bsp-placeholder svg { width: 32px; height: 32px; }
.bs-preview .bsp-placeholder span { font-size: 12px; font-weight: 500; }
.bs-body { padding: 14px; }
.bs-label { font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--text3); margin-bottom: 8px; }
.bs-url-row { display: flex; gap: 6px; }
.bs-url-row input { flex: 1; font-size: 12px; padding: 8px 10px; }
.bs-apply { padding: 8px 12px; background: var(--primary); color: #fff;
  border-radius: var(--radius-sm); font-size: 11.5px; font-weight: 700;
  cursor: pointer; transition: var(--trans); flex-shrink: 0; }
.bs-apply:hover { background: #ea6c0a; }
.bs-text-row { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }

/* Category manager */
.cat-manager-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; margin-bottom: 20px; }
.custom-cat-add-row { display: grid; grid-template-columns: 1fr auto; gap: 8px; margin: 10px 0 10px; }
.custom-cat-list { display: grid; gap: 8px; margin-bottom: 14px; }
.custom-cat-item {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg);
  padding: 9px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.custom-cat-text strong { display: block; font-size: 12px; color: var(--text); }
.custom-cat-text span { display: block; font-size: 11px; color: var(--text4); font-family: var(--font-m); }
.custom-cat-remove {
  border: 1px solid var(--border2);
  background: var(--white);
  color: var(--text3);
  border-radius: 999px;
  padding: 6px 11px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.custom-cat-remove:hover { border-color: #FCA5A5; color: #B91C1C; }
.custom-cat-empty {
  border: 1px dashed var(--border2);
  border-radius: var(--radius-sm);
  padding: 9px 10px;
  font-size: 11.5px;
  color: var(--text4);
  margin-bottom: 12px;
}
.cat-manager-card {
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; background: var(--white); transition: var(--trans);
}
.cat-manager-card:hover { box-shadow: var(--shadow-md); }
.cmc-img { aspect-ratio: 16/9; background: var(--bg); position: relative; overflow: hidden; }
.cmc-img img { width: 100%; height: 100%; object-fit: cover; }
.cmc-img .cmc-placeholder {
  position: absolute; inset: 0; display: flex; align-items: center;
  justify-content: center; color: var(--text5);
}
.cmc-img .cmc-placeholder svg { width: 28px; height: 28px; }
.cmc-body { padding: 12px; }
.cmc-name { font-family: var(--font-d); font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.cmc-url { display: flex; gap: 6px; }
.cmc-url input { flex: 1; font-size: 11.5px; padding: 7px 10px; }
.cmc-url button { padding: 7px 10px; background: var(--primary); color: #fff;
  border-radius: var(--radius-sm); font-size: 11px; font-weight: 700;
  cursor: pointer; transition: var(--trans); }
.cmc-url button:hover { background: #ea6c0a; }

/* Branding studio */
.branding-studio {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  padding: 14px;
  margin-bottom: 16px;
}
.branding-title {
  font-family: var(--font-d);
  font-size: 13.5px;
  font-weight: 800;
  color: var(--text);
}
.branding-sub {
  font-size: 12px;
  color: var(--text3);
  margin: 4px 0 12px;
}
.brand-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.brand-preset-btn {
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text2);
  border-radius: 999px;
  padding: 7px 11px;
  font-size: 11.5px;
  font-weight: 700;
  cursor: pointer;
  transition: var(--trans);
}
.brand-preset-btn:hover {
  border-color: var(--primary-md);
  color: var(--primary);
}
.brand-preset-btn.active {
  background: var(--primary-lt);
  border-color: var(--primary);
  color: var(--primary);
}
.brand-additions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.brand-addition {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text2);
  font-size: 12px;
  font-weight: 600;
}
.brand-addition input {
  accent-color: var(--primary);
}

/* Supabase setup wizard */
.supabase-tools {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg);
  padding: 14px;
  margin-bottom: 16px;
}
.supabase-tools-head {
  font-family: var(--font-d);
  font-size: 13.5px;
  font-weight: 800;
  color: var(--text);
}
.supabase-tools p {
  margin: 6px 0 12px;
  font-size: 12px;
  color: var(--text3);
  line-height: 1.5;
}
.supabase-tools-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.sb-mini-btn {
  width: auto;
  padding: 9px 12px;
  font-size: 12px;
  font-weight: 700;
}
.sb-mini-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
}

/* Stat cards enhanced */
.a-stat { cursor: default; }
.a-stat-trend { display: flex; align-items: center; gap: 4px; margin-top: 6px; }
.a-stat-trend svg { width: 12px; height: 12px; }
.trend-up { color: var(--green); }
.trend-down { color: var(--red); }
.trend-label { font-size: 11px; font-weight: 600; }

/* Admin footer */
.admin-footer {
  padding: 16px 24px; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  background: var(--white); flex-shrink: 0;
}
.admin-footer-left { font-size: 12px; color: var(--text4); }
.admin-footer-left strong { color: var(--text3); font-weight: 600; }
.admin-footer-right { display: flex; align-items: center; gap: 10px; }

/* Product form image section */
.prod-img-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 8px;
}
.prod-img-slot {
  aspect-ratio: 1; border: 2px dashed var(--border); border-radius: var(--radius-sm);
  position: relative; overflow: hidden; cursor: pointer; background: var(--bg);
  transition: var(--trans);
}
.prod-img-slot:hover { border-color: var(--primary); background: var(--primary-lt); }
.prod-img-slot img { width: 100%; height: 100%; object-fit: cover; display: block; }
.prod-img-slot .pis-add {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 4px; color: var(--text4);
}
.prod-img-slot .pis-add svg { width: 20px; height: 20px; }
.prod-img-slot .pis-add span { font-size: 10px; font-weight: 600; }
.prod-img-slot.has-img .pis-add { display: none; }
.pf-img-textarea { min-height: 86px; }
.pf-img-tools {
  margin-top: 9px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.pf-mini-btn {
  width: auto;
  padding: 8px 12px;
  font-size: 11.5px;
  border-radius: 8px;
}
.pf-img-status {
  font-size: 11.5px;
  color: var(--text3);
  font-weight: 600;
}
.pf-quick-url-row {
  margin-top: 8px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}
.pf-url-help {
  margin-top: 8px;
  padding: 9px 10px;
  border-radius: var(--radius-sm);
  border: 1px dashed var(--border2);
  background: var(--bg);
}
.pf-url-help-head {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 6px;
}
.pf-url-help-links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 6px;
}
.pf-url-help-links a {
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--text2);
  font-size: 11px;
  font-weight: 700;
  transition: var(--trans);
}
.pf-url-help-links a:hover {
  border-color: var(--primary-md);
  color: var(--primary);
  background: var(--primary-lt);
}
.pf-url-help p {
  margin: 0;
  font-size: 11.5px;
  color: var(--text3);
  line-height: 1.45;
}
.pf-preview-wrap {
  margin-top: 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg);
  padding: 12px;
}
.pf-preview-head {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text4);
  margin-bottom: 10px;
}
.pf-card-preview {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  overflow: hidden;
}
.pfp-shell {
  display: grid;
  grid-template-columns: 112px 1fr;
  min-height: 112px;
}
.pfp-media {
  position: relative;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-right: 1px solid var(--border);
}
.pfp-media svg { width: 38px; height: 38px; color: var(--text5); display: none; }
.pfp-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pfp-media.pfp-fallback img { display: none; }
.pfp-media.pfp-fallback svg { display: block; }
.pfp-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  background: rgba(17,24,39,0.9);
  color: #fff;
  border-radius: 999px;
  padding: 3px 7px;
}
.pfp-body { padding: 10px 12px; }
.pfp-brand {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text4);
  margin-bottom: 3px;
}
.pfp-name {
  font-family: var(--font-d);
  font-size: 13px;
  font-weight: 800;
  color: var(--text);
  line-height: 1.25;
}
.pfp-tagline {
  font-size: 11.5px;
  color: var(--text3);
  line-height: 1.4;
  margin-top: 4px;
}
.pfp-meta {
  margin-top: 7px;
  font-size: 10.5px;
  color: var(--text4);
}
.pfp-highlights {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.pfp-highlights span {
  font-size: 10px;
  color: var(--text3);
  border: 1px solid var(--border);
  background: var(--bg);
  border-radius: 999px;
  padding: 2px 7px;
}
.pfp-variants {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.pfp-variant {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  color: var(--text2);
  border: 1px solid var(--border);
  background: var(--bg);
  border-radius: 999px;
  padding: 2px 8px;
}
.pfp-variant-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1px solid rgba(15, 23, 42, 0.28);
  background: var(--v-color, #cbd5e1);
  flex-shrink: 0;
}
.pfp-footer {
  margin-top: 9px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 10px;
}
.pfp-footer strong {
  display: block;
  font-family: var(--font-m);
  color: var(--text);
  font-size: 14px;
}
.pfp-footer small {
  display: block;
  font-family: var(--font-m);
  font-size: 10.5px;
  color: var(--text4);
  text-decoration: line-through;
}
.pfp-footer em {
  display: inline-block;
  margin-top: 2px;
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 10px;
  font-style: normal;
  color: var(--green);
  background: var(--green-lt);
}
.pfp-stock {
  font-size: 10.5px;
  font-weight: 700;
  color: var(--text4);
  white-space: nowrap;
}

/* Site footer (in explore/site view) */
.site-footer {
  background: var(--white); border-top: 1px solid var(--border);
  padding: 32px 28px 20px; margin-top: 40px;
}
.sf-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1.2fr; gap: 24px; margin-bottom: 28px; }
.sf-brand-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.sf-logo-mark {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--primary); display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 18px rgba(249,115,22,0.35);
}
.sf-logo-mark svg { width: 18px; height: 18px; color: #fff; fill: currentColor; }
.sf-brand-title strong {
  display: block; font-family: var(--font-d); font-size: 14px; font-weight: 800; color: var(--text);
}
.sf-brand-title span {
  display: block; font-size: 10px; letter-spacing: 1.1px; text-transform: uppercase; color: var(--text4);
}
.sf-brand p { font-size: 13px; color: var(--text3); line-height: 1.7; margin: 10px 0 14px; max-width: 280px; }
.sf-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 12px;
}
.sf-signal {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid var(--primary-md);
  background: var(--primary-lt);
  color: var(--primary);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.2px;
}
.sf-col h5 {
  font-family: var(--font-d); font-size: 12px; font-weight: 700; letter-spacing: 1.2px;
  text-transform: uppercase; color: var(--text4); margin-bottom: 12px;
}
.sf-col a {
  display: block; font-size: 13px; color: var(--text3); margin-bottom: 8px;
  cursor: pointer; transition: var(--trans);
}
.sf-col a:hover { color: var(--primary); }
.sf-blog-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg);
  padding: 10px 11px;
  margin-bottom: 10px;
}
.sf-blog-card strong {
  display: block;
  font-size: 12.5px;
  font-weight: 800;
  color: var(--text2);
  line-height: 1.35;
  margin-bottom: 6px;
}
.sf-blog-card p {
  margin: 0;
  font-size: 12px;
  color: var(--text3);
  line-height: 1.55;
}
.sf-bottom {
  padding-top: 18px; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px;
}
.sf-bottom-left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
.sf-bottom p { font-size: 12px; color: var(--text4); }
.sf-admin-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--white);
  color: var(--text2);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2px;
  cursor: pointer;
  transition: var(--trans);
}
.sf-admin-link:hover {
  border-color: var(--primary-md);
  background: var(--primary-lt);
  color: var(--primary);
}
.sf-socials { display: flex; gap: 8px; }
.sf-social {
  width: 32px; height: 32px; border: 1px solid var(--border); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text3); cursor: pointer; transition: var(--trans);
}
.sf-social:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-lt); }
.sf-social svg { width: 14px; height: 14px; }

/* Responsive upgrades */
@media(max-width:900px){
  .admin-sidebar-nav { display: none; }
  .sf-grid { grid-template-columns: 1fr 1fr; }
  .banner-manager { grid-template-columns: 1fr; }
  .cat-manager-grid { grid-template-columns: 1fr 1fr; }
}
@media(max-width:600px){
  .sf-grid { grid-template-columns: 1fr; }
  .sf-bottom-left { width: 100%; }
  .brand-additions { grid-template-columns: 1fr; }
  .supabase-tools-row .sb-mini-btn { flex: 1 1 100%; justify-content: center; }
  .cat-manager-grid { grid-template-columns: 1fr; }
  .prod-img-grid { grid-template-columns: repeat(2,1fr); }
  .pf-quick-url-row { grid-template-columns: 1fr; }
  .pfp-shell { grid-template-columns: 1fr; }
  .pfp-media { min-height: 148px; border-right: none; border-bottom: 1px solid var(--border); }
}

/* ===================== ANIMATIONS ===================== */
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.page.active { animation: fadeIn 0.25s ease; }
.admin-section.active { animation: fadeIn 0.2s ease; }

/* ===================== CLEAN UI REFACTOR ===================== */
:root {
  --shadow-sm: 0 1px 3px rgba(15,23,42,0.08);
  --shadow-md: 0 3px 10px rgba(15,23,42,0.1);
  --shadow-lg: 0 8px 20px rgba(15,23,42,0.12);
}

.app-card,
.topbar,
.logo-icon {
  box-shadow: none;
}

.search-input:focus,
.form-input:focus,
.form-select:focus,
.btn-cta.blue:hover,
.btn-primary:hover {
  box-shadow: none;
}

.hero-pulse,
.p-card::after,
.a-stat::after {
  display: none !important;
}

.hero-banner-img:hover,
.promo-img-card:hover,
.p-card:hover {
  transform: none;
  box-shadow: none;
}

.hero-banner-img:hover img,
.promo-img-card:hover img,
.p-card:hover .p-card-img img {
  transform: none;
}

.sidebar {
  transition: width 0.28s ease, transform 0.28s ease;
}

.main {
  transition: margin 0.28s ease;
}

.sidebar-toggle {
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text2);
  cursor: pointer;
  transition: var(--trans);
}

.sidebar-toggle:hover {
  border-color: var(--primary-md);
  color: var(--primary);
}

.sidebar-toggle svg {
  width: 18px;
  height: 18px;
}

.btn-admin-header {
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--text2);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2px;
  cursor: pointer;
  transition: var(--trans);
}

.btn-admin-header:hover {
  border-color: var(--primary-md);
  color: var(--primary);
  background: var(--primary-lt);
}

.btn-admin-header svg {
  width: 15px;
  height: 15px;
}

body.sidebar-collapsed .sidebar {
  width: 84px;
}

body.sidebar-collapsed .sidebar-logo {
  justify-content: center;
  padding: 14px 8px;
}

body.sidebar-collapsed .logo-text,
body.sidebar-collapsed .sidebar-label,
body.sidebar-collapsed .theme-switcher .ts-label,
body.sidebar-collapsed .theme-switcher .ts-track {
  display: none;
}

body.sidebar-collapsed .nav-item {
  font-size: 0;
  gap: 0;
  justify-content: center;
  padding: 10px 0;
}

body.sidebar-collapsed .nav-item svg {
  width: 18px;
  height: 18px;
}

body.sidebar-collapsed .nav-badge {
  position: absolute;
  top: 4px;
  right: 8px;
  margin-left: 0;
}

body.sidebar-collapsed .theme-switcher {
  justify-content: center;
  padding: 10px;
}

body.sidebar-collapsed .btn-admin-sidebar {
  font-size: 0;
  justify-content: center;
  padding: 10px;
}

body.sidebar-collapsed .btn-admin-sidebar svg {
  margin: 0;
}

[data-theme="dark"] .topbar,
[data-theme="dark"] .ck-main,
[data-theme="dark"] .ck-summary,
[data-theme="dark"] .site-footer,
[data-theme="dark"] .p-card,
[data-theme="dark"] .admin-shell,
[data-theme="dark"] .a-stat {
  background: rgba(20, 22, 28, 0.62) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

[data-theme="dark"] .topbar-toggle-group,
[data-theme="dark"] .search-input,
[data-theme="dark"] .btn-admin-header,
[data-theme="dark"] .sf-admin-link,
[data-theme="dark"] .icon-btn,
[data-theme="dark"] .user-pill {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.14);
}

[data-theme="dark"] .admin-header-dot {
  border-color: rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.75);
}

@media(max-width:900px){
  .sidebar-toggle { display: none; }
  .btn-admin-header { display: none; }
  .topbar { gap: 10px; }
}

/* Admin scroll reliability */
#adminDashScreen {
  min-height: 0;
}
#adminDashScreen .admin-body {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior-y: contain;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}

/* ===================== BRAND + HOME UPGRADES ===================== */
.brand-logo-img {
  height: 44px;
  width: auto;
  object-fit: contain;
  display: block;
}

.footer-logo-img {
  height: 44px;
  width: auto;
  object-fit: contain;
  display: block;
  margin-bottom: 10px;
}

body.sidebar-collapsed .brand-logo-img {
  height: 32px;
}

#page-explore .cat-chip.active {
  background: #ea580c;
  border-color: #ea580c;
}

#page-explore .hero-banner-img .hb-overlay {
  background: linear-gradient(132deg, #ff7a1a 0%, #ea580c 60%, #c2410c 100%) !important;
}

#page-explore #promoCard1 .pic-overlay {
  background: linear-gradient(140deg, #ffedd5 0%, #fdba74 100%) !important;
}

#page-explore #promoCard2 .pic-overlay {
  background: linear-gradient(140deg, #dcfce7 0%, #86efac 100%) !important;
}

.image-marquee {
  margin: 18px 0 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  overflow: hidden;
  position: relative;
}

.image-marquee-track {
  display: flex;
  align-items: center;
  gap: 10px;
  width: max-content;
  padding: 10px 12px;
  animation: imageMarqueeMove 22s linear infinite;
}

.image-marquee:hover .image-marquee-track,
.image-marquee:focus-within .image-marquee-track {
  animation-play-state: paused;
}

.image-tile {
  width: 168px;
  height: 96px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: #e5e7eb;
  flex: 0 0 auto;
  cursor: pointer;
}

.image-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  image-rendering: auto;
  filter: none;
}

.image-marquee-center {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid rgba(249, 115, 22, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  color: rgba(249, 115, 22, 0.9);
  background: transparent;
  pointer-events: none;
}

.image-marquee-center svg {
  width: 46px;
  height: 46px;
  color: inherit;
}

@keyframes imageMarqueeMove {
  0% { transform: translateX(-42%); }
  100% { transform: translateX(0%); }
}

[data-theme="dark"] .image-marquee {
  background: rgba(20, 22, 28, 0.62);
  border-color: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

[data-theme="dark"] .image-tile {
  border-color: rgba(255, 255, 255, 0.16);
}

[data-theme="dark"] .image-marquee-center {
  color: rgba(251, 146, 60, 0.95);
  border-color: rgba(251, 146, 60, 0.58);
}

@media(max-width:900px){
  .image-marquee { margin: 14px 0 6px; }
  .image-tile { width: 136px; height: 84px; }
  .image-marquee-center { width: 62px; height: 62px; }
  .image-marquee-center svg { width: 38px; height: 38px; }
}

/* ===================== PRODUCT CARD REWORK ===================== */
.products-scroll {
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
  gap: 16px;
}

.p-card,
[data-theme="dark"] .p-card {
  border: 2px solid #111 !important;
  border-radius: 28px;
  background: #fff !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 8px;
}

.p-card::after {
  display: none !important;
}

.p-card:hover {
  transform: translateY(-1px);
  box-shadow: none !important;
}

.p-card .p-card-img {
  aspect-ratio: 4 / 5;
  border-radius: 22px;
  overflow: hidden;
  position: relative;
  border: 1.5px solid #111;
  background: #0f172a;
}

.p-card .p-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: none !important;
}

.p-card-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.03) 24%, rgba(0,0,0,0.82) 100%);
  pointer-events: none;
}

.p-card .wish-btn {
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border: 1.5px solid #111;
  box-shadow: none;
}

.p-card .p-badge {
  top: 10px;
  left: 10px;
  border: 1.5px solid #111;
  background: #fff;
  color: #111;
}

.p-card .p-badge.hot,
.p-card .p-badge.new,
.p-card .p-badge.sale {
  background: #fff;
  color: #111;
}

.p-card .p-card-body {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 16px;
  color: #fff;
  z-index: 2;
}

.p-card .p-card-brand {
  font-size: 10px;
  color: rgba(255,255,255,0.78);
  letter-spacing: 1px;
  margin-bottom: 5px;
}

.p-card .p-card-name {
  font-size: 25px;
  line-height: 1.08;
  color: #fff;
  margin-bottom: 8px;
}

.p-card .p-card-tagline {
  font-size: 12px;
  line-height: 1.45;
  color: rgba(255,255,255,0.86);
  margin: -2px 0 8px;
}

.p-card-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.55);
  font-size: 11px;
  color: rgba(255,255,255,0.88);
  margin-bottom: 10px;
  background: rgba(0,0,0,0.25);
}

.p-card-meta-icon {
  width: 14px;
  height: 14px;
  display: inline-flex;
}

.p-card-meta-icon svg {
  width: 14px;
  height: 14px;
}

.p-card .p-card-footer {
  align-items: flex-end;
  gap: 10px;
}

.p-card .p-card-price {
  font-size: 20px;
  color: #fff;
}

.p-card .p-card-price-orig {
  color: rgba(255,255,255,0.72);
}

.p-card .p-card-disc {
  background: #fff;
  color: #111;
}

.p-card .p-card-add {
  height: 44px;
  min-width: 126px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1.5px solid #111;
  background: #fff;
  color: #111;
}

.p-card .p-card-add:hover {
  background: #f3f4f6;
  transform: none;
}

.p-card .p-card-add svg {
  color: #111;
}

/* ===================== MARQUEE ICON OVERLAYS ===================== */
.image-tile {
  position: relative;
  border: 1.5px solid #111;
}

.image-tile::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.26));
  pointer-events: none;
}

.image-tile-icon {
  position: absolute;
  right: 8px;
  top: 8px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid #111;
  background: rgba(255,255,255,0.94);
  color: #111;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

.image-tile-icon svg {
  width: 16px;
  height: 16px;
}

.image-tile:focus-visible {
  outline: 3px solid rgba(249, 115, 22, 0.45);
  outline-offset: 2px;
}

@media(max-width:900px){
  .products-scroll { grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); }
  .p-card .p-card-name { font-size: 20px; }
  .p-card .p-card-price { font-size: 17px; }
  .p-card .p-card-add { min-width: 96px; height: 38px; }
}

/* Force-hide footer outside Explore page */
body.hide-site-footer #siteFooter {
  display: none !important;
}

/* ===================== FLAT VISUAL CLEANUP ===================== */
/* Remove glow, blur, blobs, and gradient overlays for a clean look */
.glass,
[data-theme="dark"] .glass,
.glass-card,
[data-theme="dark"] .glass-card,
[data-theme="dark"] .topbar,
[data-theme="dark"] .ck-main,
[data-theme="dark"] .ck-summary,
[data-theme="dark"] .site-footer,
[data-theme="dark"] .p-card,
[data-theme="dark"] .admin-shell,
[data-theme="dark"] .a-stat,
[data-theme="dark"] .image-marquee {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
}

.overlay,
.admin-overlay {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.banner-card,
.p-card-gradient,
.image-tile::after {
  background-image: none !important;
}

.banner-card::before,
.banner-card::after,
.banner-card .pulse-dot,
.image-marquee-center {
  display: none !important;
}

/* ===================== CRISP UI POLISH ===================== */
.app-outer {
  background: #f6f7fb;
}

.topbar {
  border-radius: 14px;
  border-color: #e6e8ef;
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.08);
}

.sidebar {
  border-right-color: #e6e8ef;
}

.nav-item {
  border-radius: 10px;
}

.nav-item.active {
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fdba74;
}

.cat-chip,
.filter-btn {
  border-color: #e5e7eb;
  font-weight: 600;
}

.cat-chip.active {
  box-shadow: 0 2px 8px rgba(249, 115, 22, 0.25);
}

.explore-grid .hero-banner-img,
.explore-grid .promo-img-card {
  border: 1px solid #e5e7eb;
}

.section-row h3 {
  letter-spacing: -0.2px;
}

.p-card {
  border-radius: 14px;
  border-color: #e5e7eb;
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.05);
}

.p-card:hover {
  transform: translateY(-1px);
  border-color: #fdba74;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.11);
}

.p-card-name {
  letter-spacing: -0.15px;
}

.p-card-add {
  border-radius: 10px;
}

.detail-layout,
.checkout-body {
  align-items: start;
}

.table-wrap,
.prod-form,
.ck-main,
.ck-summary,
.order-detail-card {
  border-color: #e5e7eb;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.04);
}

.form-input,
.form-select,
.form-textarea {
  border-color: #dfe3ea;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: #fb923c;
  box-shadow: 0 0 0 3px rgba(251, 146, 60, 0.16);
}

.btn-cta.blue {
  box-shadow: 0 6px 14px rgba(249, 115, 22, 0.28);
}

.btn-cta.blue:hover {
  box-shadow: 0 8px 18px rgba(234, 108, 10, 0.34);
}

.icon-btn,
.wish-btn,
.tbl-btn,
.cd-remove,
.cd-close {
  border: 1px solid #e5e7eb;
}

button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.cat-chip:focus-visible,
.nav-item:focus-visible,
.icon-btn:focus-visible,
.tbl-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(251, 146, 60, 0.18);
}

@media (max-width: 900px) {
  .topbar {
    margin: 10px 10px 0;
    border-radius: 12px;
  }

  .page {
    padding: 20px 14px 22px;
  }

  .p-card {
    border-radius: 12px;
  }
}

/* ===================== CRISP UI POLISH V2 ===================== */
.page {
  max-width: 1320px;
  width: 100%;
  margin: 0 auto;
}

.explore-header {
  gap: 12px;
  flex-wrap: wrap;
}

.explore-header h2 {
  font-size: clamp(21px, 2.2vw, 30px);
  line-height: 1.1;
}

.section-row {
  margin-bottom: 14px;
  margin-top: 24px;
}

.products-scroll {
  grid-template-columns: repeat(auto-fill, minmax(235px, 1fr));
  gap: 14px;
}

.p-card,
[data-theme="dark"] .p-card {
  border: 1.5px solid #dde2eb !important;
  border-radius: 16px;
  background: #fff !important;
  padding: 0;
  overflow: hidden;
}

.p-card .p-card-img {
  aspect-ratio: 10 / 12;
  border: none;
  border-radius: 0;
  background: #f2f4f8;
}

.p-card .p-card-img img {
  transform: none !important;
}

.p-card-gradient {
  display: none;
}

.p-card .p-card-body {
  position: static;
  padding: 14px;
  color: var(--text);
}

.p-card .p-card-brand {
  color: var(--text4);
  font-size: 10.5px;
  margin-bottom: 4px;
}

.p-card .p-card-name {
  color: var(--text);
  font-size: 15px;
  line-height: 1.3;
  margin-bottom: 8px;
  min-height: 38px;
}

.p-card .p-card-tagline {
  color: var(--text3);
  margin: -2px 0 8px;
}

.p-card-meta {
  margin-bottom: 10px;
  color: var(--text3);
  border: 1px solid #e5e7eb;
  background: #f8fafc;
}

.p-card-meta-icon svg {
  color: var(--text4);
}

.p-card .p-card-price {
  color: var(--text);
  font-size: 15px;
}

.p-card .p-card-price-orig {
  color: var(--text4);
}

.p-card .p-card-disc {
  background: #ecfdf5;
  color: #047857;
}

.p-card .p-card-add {
  height: 34px;
  min-width: 34px;
  padding: 0;
  border-radius: 9px;
  border: none;
  background: var(--primary);
  color: #fff;
}

.p-card .p-card-add:hover {
  background: #ea6c0a;
  transform: none;
}

.p-card .p-card-add svg {
  color: #fff;
}

.p-card .wish-btn {
  border-color: #e5e7eb;
  background: #fff;
}

.ck-sidebar {
  position: sticky;
  top: 88px;
}

@media (max-width: 900px) {
  .products-scroll {
    grid-template-columns: repeat(auto-fill, minmax(195px, 1fr));
    gap: 12px;
  }

  .p-card .p-card-name {
    min-height: 0;
    font-size: 14px;
  }

  .ck-sidebar {
    position: static;
  }
}

/* ===================== DARK GLASS REFLECTION ===================== */
@keyframes darkGlareSweep {
  0% { transform: translateX(-35%) translateY(0) rotate(8deg); opacity: 0; }
  8% { opacity: 0.14; }
  48% { opacity: 0.14; }
  100% { transform: translateX(145%) translateY(0) rotate(8deg); opacity: 0; }
}

@keyframes darkSilverDrift {
  0% { background-position: 0% 0%; }
  100% { background-position: 220% 0%; }
}

[data-theme="dark"] .app-outer {
  background:
    radial-gradient(1200px 520px at 16% -8%, rgba(255,255,255,0.06), transparent 62%),
    radial-gradient(900px 420px at 85% 12%, rgba(148,163,184,0.12), transparent 60%),
    linear-gradient(180deg, #07090f 0%, #0b1220 54%, #080d18 100%);
}

[data-theme="dark"] .topbar,
[data-theme="dark"] .sidebar,
[data-theme="dark"] .site-footer,
[data-theme="dark"] .hero-banner-img,
[data-theme="dark"] .promo-img-card,
[data-theme="dark"] .image-marquee,
[data-theme="dark"] .p-card,
[data-theme="dark"] .table-wrap,
[data-theme="dark"] .prod-form,
[data-theme="dark"] .ck-main,
[data-theme="dark"] .ck-summary,
[data-theme="dark"] .admin-shell,
[data-theme="dark"] .a-stat,
[data-theme="dark"] .admin-topbar {
  background: linear-gradient(140deg, rgba(10,16,30,0.72), rgba(17,24,39,0.46)) !important;
  border: 1px solid rgba(203,213,225,0.26) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.06) inset,
    0 14px 38px rgba(2,6,23,0.42) !important;
  backdrop-filter: blur(16px) saturate(135%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(135%) !important;
  position: relative;
  overflow: hidden;
}

[data-theme="dark"] .topbar::before,
[data-theme="dark"] .sidebar::before,
[data-theme="dark"] .site-footer::before,
[data-theme="dark"] .hero-banner-img::before,
[data-theme="dark"] .promo-img-card::before,
[data-theme="dark"] .image-marquee::before,
[data-theme="dark"] .p-card::before,
[data-theme="dark"] .table-wrap::before,
[data-theme="dark"] .prod-form::before,
[data-theme="dark"] .ck-main::before,
[data-theme="dark"] .ck-summary::before,
[data-theme="dark"] .admin-shell::before,
[data-theme="dark"] .a-stat::before,
[data-theme="dark"] .admin-topbar::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: linear-gradient(108deg, transparent 32%, rgba(255,255,255,0.2) 48%, transparent 62%);
  transform: translateX(-35%) rotate(8deg);
  animation: darkGlareSweep 8.5s linear infinite;
  pointer-events: none;
}

[data-theme="dark"] .topbar::after,
[data-theme="dark"] .sidebar::after,
[data-theme="dark"] .site-footer::after,
[data-theme="dark"] .hero-banner-img::after,
[data-theme="dark"] .promo-img-card::after,
[data-theme="dark"] .image-marquee::after,
[data-theme="dark"] .p-card::after,
[data-theme="dark"] .table-wrap::after,
[data-theme="dark"] .prod-form::after,
[data-theme="dark"] .ck-main::after,
[data-theme="dark"] .ck-summary::after,
[data-theme="dark"] .admin-shell::after,
[data-theme="dark"] .a-stat::after,
[data-theme="dark"] .admin-topbar::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1.5px;
  background: linear-gradient(90deg, transparent 0%, rgba(226,232,240,0.8) 50%, transparent 100%);
  background-size: 220% 100%;
  animation: darkSilverDrift 6s linear infinite;
  pointer-events: none;
}

[data-theme="dark"] .overlay,
[data-theme="dark"] .admin-overlay {
  background: rgba(3, 8, 20, 0.54);
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

[data-theme="dark"] .image-tile {
  border-color: rgba(226,232,240,0.4);
}

[data-theme="dark"] .image-tile-icon {
  border-color: rgba(226,232,240,0.42);
  background: rgba(15,23,42,0.76);
  color: #e2e8f0;
}

/* ===================== PRODUCT CARDS (FRAMED + FULL IMAGE) ===================== */
#productsGrid.products-scroll {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 16px;
  align-items: stretch;
}

#productsGrid .p-card {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  min-height: 100%;
  border: 2px solid #111 !important;
  border-radius: 26px;
  background: #fff !important;
  box-shadow: none !important;
  padding: 8px;
  overflow: hidden;
}

#productsGrid .p-card::after {
  display: none !important;
}

#productsGrid .p-card .p-card-img {
  display: block !important;
  aspect-ratio: 10 / 12; /* ~10% taller than previous framing */
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  border: 1.5px solid #111;
  background: #0f172a;
}

#productsGrid .p-card .p-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: none !important;
}

#productsGrid .p-card-gradient {
  display: block !important;
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.03) 24%, rgba(0,0,0,0.82) 100%);
  pointer-events: none;
}

#productsGrid .p-card .p-card-body {
  position: absolute !important;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 16px;
  color: #fff !important;
  background: transparent !important;
  z-index: 2;
}

#productsGrid .p-card .p-card-brand {
  color: rgba(255,255,255,0.78) !important;
  font-size: 10px;
  letter-spacing: 1px;
  margin-bottom: 5px;
}

#productsGrid .p-card .p-card-name {
  color: #fff !important;
  font-size: 23px;
  line-height: 1.08;
  margin-bottom: 8px;
  min-height: 0;
}

#productsGrid .p-card .p-card-tagline {
  color: rgba(255,255,255,0.86) !important;
  font-size: 12px;
  line-height: 1.45;
  margin: -2px 0 8px;
}

#productsGrid .p-card-meta {
  border: 1px solid rgba(255,255,255,0.55);
  background: rgba(0,0,0,0.25);
  color: rgba(255,255,255,0.88) !important;
  margin-bottom: 10px;
}

#productsGrid .p-card .p-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 10px;
}

#productsGrid .p-card .p-card-price {
  color: #fff !important;
  font-size: 20px;
}

#productsGrid .p-card .p-card-price-orig {
  color: rgba(255,255,255,0.72) !important;
}

#productsGrid .p-card .p-card-disc {
  background: #fff;
  color: #111;
}

#productsGrid .p-card .p-card-add {
  display: flex !important;
  height: 42px;
  min-width: 116px;
  padding: 0 14px;
  margin-left: auto;
  border-radius: 999px;
  border: 1.5px solid #111;
  background: #fff;
  color: #111;
}

#productsGrid .p-card .p-card-add svg {
  color: #111;
}

#productsGrid .p-card .p-card-add:hover {
  background: #f3f4f6;
  transform: none;
}

#productsGrid .p-card .wish-btn {
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border: 1.5px solid #111;
  background: #fff;
  box-shadow: none;
}

#productsGrid .p-card .p-badge {
  top: 10px;
  left: 10px;
  border: 1.5px solid #111;
  background: #fff;
  color: #111;
}

@media (max-width: 900px) {
  #productsGrid.products-scroll {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 12px;
  }

  #productsGrid .p-card .p-card-name {
    font-size: 19px;
  }

  #productsGrid .p-card .p-card-price {
    font-size: 17px;
  }

  #productsGrid .p-card .p-card-add {
    min-width: 94px;
    height: 38px;
  }
}

/* Laptop and larger: make product cards 10% taller */
@media (min-width: 901px) {
  #productsGrid .p-card .p-card-img {
    aspect-ratio: 10 / 13.2;
  }
}

/* ===================== DARK MODE: CHARCOAL VANTA + SILVER GLARE ===================== */
[data-theme="dark"] {
  --outer-bg: #020203;
  --bg: #050607;
  --white: #0a0b0d;
  --card-bg: #0c0d10;
  --border: #8a909a;
  --border2: #9aa1ab;
  --text: #eceef1;
  --text2: #d3d7dd;
  --text3: #a4aab4;
  --text4: #7f8794;
  --text5: #626a76;
}

[data-theme="dark"] .app-outer {
  background:
    radial-gradient(1200px 600px at 18% -10%, rgba(201, 209, 220, 0.09), transparent 64%),
    radial-gradient(980px 540px at 82% 0%, rgba(124, 133, 148, 0.1), transparent 62%),
    linear-gradient(180deg, #010102 0%, #050608 52%, #030407 100%);
}

[data-theme="dark"] .topbar,
[data-theme="dark"] .sidebar,
[data-theme="dark"] .site-footer,
[data-theme="dark"] .hero-banner-img,
[data-theme="dark"] .promo-img-card,
[data-theme="dark"] .image-marquee,
[data-theme="dark"] .p-card,
[data-theme="dark"] .table-wrap,
[data-theme="dark"] .prod-form,
[data-theme="dark"] .ck-main,
[data-theme="dark"] .ck-summary,
[data-theme="dark"] .admin-shell,
[data-theme="dark"] .a-stat,
[data-theme="dark"] .admin-topbar {
  background: linear-gradient(145deg, rgba(7, 8, 10, 0.92), rgba(14, 16, 19, 0.78)) !important;
  border: 1px solid rgba(186, 194, 205, 0.42) !important;
  box-shadow:
    0 0 0 1px rgba(238, 242, 248, 0.06) inset,
    0 14px 38px rgba(0, 0, 0, 0.5) !important;
  backdrop-filter: blur(12px) saturate(125%) !important;
  -webkit-backdrop-filter: blur(12px) saturate(125%) !important;
}

[data-theme="dark"] .topbar::before,
[data-theme="dark"] .sidebar::before,
[data-theme="dark"] .site-footer::before,
[data-theme="dark"] .hero-banner-img::before,
[data-theme="dark"] .promo-img-card::before,
[data-theme="dark"] .image-marquee::before,
[data-theme="dark"] .p-card::before,
[data-theme="dark"] .table-wrap::before,
[data-theme="dark"] .prod-form::before,
[data-theme="dark"] .ck-main::before,
[data-theme="dark"] .ck-summary::before,
[data-theme="dark"] .admin-shell::before,
[data-theme="dark"] .a-stat::before,
[data-theme="dark"] .admin-topbar::before {
  background-image: linear-gradient(110deg, transparent 30%, rgba(245, 248, 252, 0.2) 49%, transparent 66%);
  animation-duration: 9.5s;
}

[data-theme="dark"] .topbar::after,
[data-theme="dark"] .sidebar::after,
[data-theme="dark"] .site-footer::after,
[data-theme="dark"] .hero-banner-img::after,
[data-theme="dark"] .promo-img-card::after,
[data-theme="dark"] .image-marquee::after,
[data-theme="dark"] .p-card::after,
[data-theme="dark"] .table-wrap::after,
[data-theme="dark"] .prod-form::after,
[data-theme="dark"] .ck-main::after,
[data-theme="dark"] .ck-summary::after,
[data-theme="dark"] .admin-shell::after,
[data-theme="dark"] .a-stat::after,
[data-theme="dark"] .admin-topbar::after {
  background: linear-gradient(90deg, transparent 0%, rgba(210, 218, 229, 0.9) 50%, transparent 100%);
  opacity: 0.9;
}

[data-theme="dark"] #productsGrid .p-card {
  background: linear-gradient(145deg, rgba(7, 8, 10, 0.95), rgba(15, 18, 22, 0.84)) !important;
  border: 1.5px solid rgba(185, 194, 206, 0.44) !important;
}

[data-theme="dark"] #productsGrid .p-card .p-card-img {
  border-color: rgba(195, 204, 216, 0.45) !important;
  background: #050608 !important;
}

[data-theme="dark"] #productsGrid .p-card .wish-btn,
[data-theme="dark"] #productsGrid .p-card .p-badge {
  background: rgba(14, 16, 19, 0.9) !important;
  border-color: rgba(194, 203, 215, 0.58) !important;
  color: #eceff4 !important;
}

[data-theme="dark"] #productsGrid .p-card .p-card-add {
  background: #fff !important;
  border-color: #fff !important;
  color: #111 !important;
}

[data-theme="dark"] #productsGrid .p-card .p-card-add svg {
  color: #111 !important;
  stroke: #111 !important;
}

/* ===================== HEADER + CHECKOUT VISIBILITY FIXES ===================== */
#appRoot[data-theme="light"] .topbar {
  border: 1px solid #111 !important;
}

[data-theme="dark"] .cd-checkout-btn,
[data-theme="dark"] #btnConfirmPay.btn-cta.blue {
  background: linear-gradient(135deg, #22d3ee, #0ea5e9) !important;
  color: #031522 !important;
  border: 1px solid rgba(186, 230, 253, 0.95) !important;
  box-shadow: 0 10px 24px rgba(14, 165, 233, 0.45) !important;
}

[data-theme="dark"] .cd-checkout-btn:hover,
[data-theme="dark"] #btnConfirmPay.btn-cta.blue:hover {
  background: linear-gradient(135deg, #67e8f9, #38bdf8) !important;
  color: #04121a !important;
}

[data-theme="dark"] .cd-checkout-btn svg,
[data-theme="dark"] #btnConfirmPay.btn-cta.blue svg {
  color: inherit !important;
  stroke: currentColor !important;
}

/* ===================== LIGHT MODE: CRISP VANTA BLACK TEXT ===================== */
#appRoot[data-theme="light"] {
  --text: #050505;
  --text2: #111111;
  --text3: #2a2a2a;
  --text4: #4b4b4b;
  --text5: #6e6e6e;
}
