/* ═══════════════════════════════════════════════════════════
   ChinaHub Premium v3.0
   "Sells harder than Temu, looks better than Alibaba"
   ═══════════════════════════════════════════════════════════ */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   1. DESIGN SYSTEM — TOKENS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
:root {
  /* Primary — ChinaHub signature red */
  --pr:    #FF2D2D;
  --pr-d:  #CC0000;
  --pr-l:  #FF6060;
  --pr-bg: rgba(255,45,45,.07);

  /* Accent — premium gold */
  --gd:    #FFB800;
  --gd-d:  #E09000;

  /* Dark navy — depth, trust */
  --nv:    #0A0E1A;
  --nv2:   #111827;
  --nv3:   #1E2940;

  /* Semantic */
  --green:  #00C06A;
  --blue:   #0EA5E9;
  --orange: #FF6A00;
  --or:     #FF6A00;
  --or-d:   #E05E00;
  --or-l:   #FF8C33;
  --gr:     #00C06A;
  --bl:     #0EA5E9;

  /* Surfaces */
  --bg:      #F2F3F7;
  --bg2:     #EBEBF0;
  --white:   #FFFFFF;
  --bd:      #E4E4E8;
  --bdr:     #E4E4E8;
  --bdr2:    #F0F0F4;

  /* Text */
  --t1: #0F1117;
  --t2: #4A4E5A;
  --t3: #9197A6;
  --t4: #C2C6D0;

  /* Shadows */
  --sh:  0 1px 6px rgba(0,0,0,.07);
  --sh2: 0 4px 20px rgba(0,0,0,.11);
  --sh3: 0 12px 44px rgba(0,0,0,.16);
  --sh-r:0 6px 28px rgba(255,45,45,.30);

  /* Legacy aliases */
  --primary:#FF2D2D; --primary-d:#CC0000;
  --border:#E4E4E8; --border2:#F0F0F4;
  --text:#0F1117; --text2:#4A4E5A; --text3:#9197A6;
  --shadow:var(--sh); --shadow2:var(--sh2);
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s8:32px;--s10:40px;
  --r:8px;--r2:12px;--r3:16px;--rc:999px;
  --nav-h:68px;--top-h:36px;--t:.18s ease;
  --bg-gray:#F2F3F7;--bg-white:#fff;
  --gd:#FFB800;--gr:#00C06A;--bl:#0EA5E9;--yl:#FFB800;
}

body { background: var(--bg); font-family: 'Cairo', 'Segoe UI', Arial, sans-serif; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   2. TOP BAR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-top-bar {
  background: var(--nv) !important;
  border-bottom: 1px solid rgba(255,45,45,.25) !important;
}
.ch-top-bar, .ch-top-bar a, .ch-top-bar span {
  color: rgba(255,255,255,.65) !important; font-size: 12px;
}
.ch-top-bar a:hover { color: var(--gd) !important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   3. HEADER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-header {
  background: #fff !important;
  border-bottom: 3px solid var(--pr) !important;
  box-shadow: 0 2px 24px rgba(0,0,0,.09) !important;
}
.ch-header.ch-nav-scrolled {
  background: rgba(255,255,255,.98) !important;
  backdrop-filter: blur(24px);
  box-shadow: 0 4px 32px rgba(0,0,0,.13) !important;
}
.ch-search-wrap {
  border: 2.5px solid var(--pr) !important;
  border-radius: 8px !important;
  overflow: hidden;
  height: 46px;
  box-shadow: 0 0 0 4px rgba(255,45,45,.07);
  transition: box-shadow .18s;
}
.ch-search-wrap:focus-within {
  box-shadow: 0 0 0 5px rgba(255,45,45,.14) !important;
}
.ch-search-input { font-size: 14px !important; }
.ch-search-btn {
  background: var(--pr) !important;
  border-radius: 0 !important;
  min-width: 56px;
  font-size: 20px;
  transition: background .15s !important;
}
.ch-search-btn:hover { background: var(--pr-d) !important; }
.ch-cart-action { background: var(--pr) !important; border-radius: 8px !important; }
.ch-cart-action:hover { background: var(--pr-d) !important; transform: scale(1.04); }
.ch-badge-dot, .ch-cart-count { background: var(--pr) !important; }
/* Logo */
.ch-logo-txt b { color: var(--pr) !important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   4. CATEGORY NAV BAR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-cat-nav {
  background: linear-gradient(90deg, #0A0E1A 0%, #111827 100%) !important;
  border-bottom: 1px solid rgba(255,45,45,.2) !important;
}
.ch-cat-nav-list li a { color: rgba(255,255,255,.78) !important; font-size: 13px !important; }
.ch-cat-nav-list li a:hover,
.ch-cat-nav-list li a.active {
  color: #FFB800 !important;
  border-bottom-color: #FFB800 !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   5. HERO SLIDER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-hero-wrap {
  background: linear-gradient(135deg, #070A14 0%, #0E1527 35%, #0A1E3A 65%, #04111F 100%);
  min-height: 520px;
  position: relative; overflow: hidden;
}
.ch-hero-wrap::before {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 800px 450px at 15% 65%, rgba(255,45,45,.20) 0%, transparent 55%),
    radial-gradient(ellipse 600px 350px at 85% 20%, rgba(255,184,0,.12) 0%, transparent 50%),
    radial-gradient(ellipse 500px 500px at 50% 100%, rgba(14,165,233,.06) 0%, transparent 60%);
}
/* Animated grid overlay */
.ch-hero-wrap::after {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 60px 60px;
}
.ch-hero-slide-bg { opacity: .06 !important; }
.hero-inner {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 54% 46%;
  align-items: center;
  gap: 40px;
  min-height: 500px;
  padding: 60px 0;
}
.hero-pill {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,45,45,.14);
  border: 1px solid rgba(255,45,45,.4);
  color: #FF8080;
  font-size: 12px; font-weight: 700;
  padding: 5px 16px; border-radius: 99px;
  margin-bottom: 12px; letter-spacing: .3px;
}
.ch-hero-version-badge {
  background: linear-gradient(135deg, var(--gd), #FF8C00);
  color: #000; font-size: 11px; font-weight: 900;
  padding: 3px 12px; border-radius: 99px;
  margin-bottom: 14px; margin-inline-end: 8px;
  display: inline-flex; align-items: center;
  box-shadow: 0 3px 12px rgba(255,184,0,.4);
}
.hero-h {
  font-size: clamp(26px, 3.2vw, 46px);
  font-weight: 900; color: #fff;
  line-height: 1.15; margin-bottom: 16px;
  letter-spacing: -.7px;
}
.hero-h span {
  background: linear-gradient(135deg, #FF6060 0%, #FFB800 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; display: block; margin-top: 4px;
}
.hero-p {
  color: rgba(255,255,255,.65);
  font-size: 14.5px; margin-bottom: 28px; line-height: 1.9;
}
.hbtn {
  padding: 14px 28px; border-radius: 8px;
  font-weight: 800; font-size: 14.5px;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 8px;
  transition: all .2s; white-space: nowrap;
}
.hbtn-primary {
  background: linear-gradient(135deg, #FF2D2D 0%, #FF6A00 100%);
  color: #fff;
  box-shadow: 0 6px 28px rgba(255,45,45,.50);
}
.hbtn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(255,45,45,.60);
  filter: brightness(1.08);
}
.hbtn-ghost {
  background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.3);
  color: #fff; backdrop-filter: blur(10px);
}
.hbtn-ghost:hover { background: rgba(255,255,255,.16); transform: translateY(-3px); }
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px; }

/* Hero Stats — glass card */
.hero-stats {
  display: grid; grid-template-columns: repeat(4,1fr);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px; overflow: hidden;
  backdrop-filter: blur(12px);
}
.hero-stat-item {
  padding: 14px 10px; text-align: center;
  transition: background .2s;
}
.hero-stat-item:hover { background: rgba(255,45,45,.12); }
.hero-stat-item + .hero-stat-item { border-inline-start: 1px solid rgba(255,255,255,.07); }
.hsi-num { font-size: 22px; font-weight: 900; color: var(--gd); margin-bottom: 4px; line-height: 1; }
.hsi-num span { font-size: 13px; color: rgba(255,184,0,.75); }
.hsi-lbl { font-size: 10px; color: rgba(255,255,255,.42); letter-spacing: .02em; }

/* Hero Image */
.hero-img { position: relative; display: flex; align-items: center; justify-content: center; }
.hero-img::before {
  content: ''; position: absolute;
  width: 420px; height: 420px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,45,45,.20) 0%, transparent 68%);
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  animation: heroGlow 4s ease-in-out infinite;
}
@keyframes heroGlow { 0%,100%{opacity:.8;transform:translate(-50%,-50%) scale(1)} 50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)} }
.hero-img img {
  width: 100%; max-width: 480px;
  border-radius: 22px;
  box-shadow: 0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.07);
  position: relative; z-index: 1;
  transition: transform .5s ease;
}
.hero-img img:hover { transform: scale(1.03) translateY(-8px); }

/* Hero dots & arrows */
.ch-hero-dot {
  width: 7px; height: 7px; border-radius: 99px;
  background: rgba(255,255,255,.25); transition: all .3s; cursor: pointer;
}
.ch-hero-dot.active { background: var(--pr); width: 24px; box-shadow: 0 0 12px rgba(255,45,45,.7); }
.hero-arr {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff; width: 42px; height: 42px;
  border-radius: 50%; transition: all .2s;
}
.hero-arr:hover { background: var(--pr); border-color: var(--pr); box-shadow: 0 4px 18px rgba(255,45,45,.5); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   6. TRUST TICKER (hidden — removed)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-trust-ticker, .ch-tz-bar, [class*="ch-tz"] { display: none !important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   7. VERSION BAR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#ch-ver-bar {
  background: linear-gradient(90deg, var(--nv2), #111827) !important;
  border-bottom: 1px solid rgba(255,45,45,.2) !important;
}
.ch-ver-badge { background: linear-gradient(135deg, var(--pr), var(--orange)); color: #fff; font-weight: 900; }
.ch-ver-cta { background: var(--pr) !important; color: #fff !important; border-radius: 5px !important; font-weight: 700 !important; }
.ch-ver-fab { background: var(--pr) !important; box-shadow: 0 4px 20px rgba(255,45,45,.5) !important; }
.ch-fab-pulse { border-color: rgba(255,45,45,.5) !important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   8. SECTION HEADERS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-sec-head {
  margin-bottom: 22px;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 8px;
}
.ch-sec-title {
  font-size: 22px; font-weight: 900; color: var(--t1);
  position: relative; padding-bottom: 11px;
  display: inline-flex; align-items: center; gap: 10px;
}
.ch-sec-title::after {
  content: '';
  position: absolute; bottom: 0; right: 0;
  width: 48px; height: 3px;
  background: linear-gradient(90deg, var(--pr), var(--gd));
  border-radius: 99px;
}
[dir=ltr] .ch-sec-title::after { right: auto; left: 0; }
.ch-sec-link {
  color: var(--pr); font-weight: 700; font-size: 13px;
  text-decoration: none; display: inline-flex; align-items: center; gap: 5px;
  transition: gap .18s;
}
.ch-sec-link:hover { gap: 10px; color: var(--pr-d); }
.ch-sec-badge-new {
  background: linear-gradient(135deg, #FF2D2D, #FF6A00);
  color: #fff; font-size: 10px; font-weight: 900;
  padding: 3px 10px; border-radius: 99px;
  display: inline-flex; align-items: center;
  box-shadow: 0 2px 10px rgba(255,45,45,.40);
  letter-spacing: .03em;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   9. FEATURED CATEGORIES (ftop)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ftop-card {
  background: #fff !important;
  border: 1.5px solid #EDEEF2 !important;
  border-radius: 14px !important;
  transition: all .2s !important;
}
.ftop-card:hover {
  border-color: var(--pr) !important;
  box-shadow: 0 8px 28px rgba(255,45,45,.15) !important;
  transform: translateY(-4px) !important;
}
.ftop-name { color: var(--t1) !important; }
.ftop-card:hover .ftop-name { color: var(--pr) !important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   10. FLASH SALE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.flash-wrap {
  background:
    linear-gradient(160deg, #120000 0%, #300000 30%, #5C0505 58%, #1A0000 100%);
  border-radius: 18px; overflow: hidden;
  box-shadow: 0 12px 60px rgba(200,0,0,.40), 0 0 0 1px rgba(255,60,0,.15);
  position: relative;
}
/* Shimmer top line */
.flash-wrap::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent 0%, #FF2D2D 30%, #FFB800 50%, #FF2D2D 70%, transparent 100%);
  animation: shimmerLine 3s ease-in-out infinite;
}
@keyframes shimmerLine {
  0%,100%{opacity:.6;background-position:0% 50%}
  50%{opacity:1;background-position:100% 50%}
}
.flash-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 24px 14px;
  border-bottom: 1px solid rgba(255,80,0,.12);
  gap: 14px; flex-wrap: wrap;
}
.flash-hd-left { display: flex; align-items: center; gap: 14px; }
.flash-bolt {
  font-size: 28px;
  filter: drop-shadow(0 0 10px rgba(255,184,0,.8));
  animation: boltPulse .6s ease-in-out infinite alternate;
  flex-shrink: 0;
}
@keyframes boltPulse { from{transform:scale(1) rotate(-5deg)} to{transform:scale(1.2) rotate(5deg)} }
.flash-ttl {
  font-size: 17px; font-weight: 900; color: #fff; line-height: 1.2;
  text-shadow: 0 2px 12px rgba(255,45,45,.5);
}
.flash-sub { font-size: 11px; color: rgba(255,255,255,.42); margin-top: 3px; }
.flash-cd-wrap { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.flash-cd-lbl {
  font-size: 9px; color: rgba(255,255,255,.38);
  text-transform: uppercase; letter-spacing: .1em;
}
.flash-cd { display: flex; align-items: center; gap: 4px; direction: ltr; }
.flash-cd span:not(.flash-cd-sep) {
  background: rgba(0,0,0,.65);
  border: 1px solid rgba(255,150,0,.25);
  color: #FFB800; font-size: 19px; font-weight: 900;
  font-family: 'Courier New', monospace;
  padding: 5px 10px; border-radius: 7px;
  min-width: 40px; text-align: center; display: inline-block;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 3px 10px rgba(0,0,0,.5),
    0 0 16px rgba(255,140,0,.15);
}
.flash-cd-sep { color: rgba(255,180,0,.6); font-size: 17px; font-weight: 900; padding: 0 1px; }
.flash-more {
  display: inline-flex; align-items: center; gap: 6px;
  background: linear-gradient(135deg, #FF2D2D, #FF7300);
  color: #fff; font-size: 12.5px; font-weight: 800;
  padding: 9px 20px; border-radius: 99px; text-decoration: none;
  white-space: nowrap; transition: all .2s;
  box-shadow: 0 4px 18px rgba(255,45,45,.5);
  flex-shrink: 0;
}
.flash-more:hover { transform: translateY(-2px) scale(1.04); box-shadow: 0 8px 28px rgba(255,45,45,.65); }

/* Flash grid */
.flash-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(136px, 1fr));
  gap: 0;
}
.flash-card {
  background: rgba(255,255,255,.04);
  border-inline-end: 1px solid rgba(255,255,255,.06);
  overflow: hidden; transition: all .22s;
  text-decoration: none; display: flex; flex-direction: column;
}
.flash-card:last-child { border: none; }
.flash-card:hover {
  background: rgba(255,255,255,.10);
  transform: translateY(-4px) scale(1.01);
  z-index: 2; position: relative;
  box-shadow: 0 12px 32px rgba(0,0,0,.4);
}
.flash-img { position: relative; aspect-ratio: 1; overflow: hidden; background: rgba(0,0,0,.25); }
.flash-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.flash-card:hover .flash-img img { transform: scale(1.08); }
.flash-disc {
  position: absolute; top: 8px; right: 8px;
  background: var(--pr); color: #fff;
  font-size: 10px; font-weight: 900;
  padding: 3px 7px; border-radius: 5px; z-index: 2;
  box-shadow: 0 2px 8px rgba(255,45,45,.5);
}
[dir=ltr] .flash-disc { right: auto; left: 8px; }
.flash-info { padding: 9px 10px 12px; flex: 1; display: flex; flex-direction: column; gap: 5px; }
.flash-name {
  color: rgba(255,255,255,.88); font-size: 11.5px; font-weight: 600; line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.flash-prices { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; margin-top: auto; }
.flash-now { color: #FFB800; font-size: 15px; font-weight: 900; }
.flash-old { color: rgba(255,255,255,.3); font-size: 11px; text-decoration: line-through; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   11. PRODUCT CARDS — Main Grid
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.pc {
  background: #fff;
  border: 1px solid #EDEEF2;
  border-radius: 12px; overflow: hidden;
  transition: box-shadow .22s, transform .22s, border-color .18s;
  position: relative;
}
.pc:hover {
  border-color: var(--pr);
  box-shadow: 0 10px 40px rgba(255,45,45,.14);
  transform: translateY(-5px);
  z-index: 2;
}
.pc-img {
  display: block; position: relative;
  aspect-ratio: 1; overflow: hidden;
  background: #F7F7FA; text-decoration: none;
}
.pc-img img, .pc-img .ch-no-img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .42s ease;
}
.pc:hover .pc-img img { transform: scale(1.08); }
.ch-no-img { display: flex; align-items: center; justify-content: center; font-size: 48px; background: #F7F7FA; }

/* Badges */
.cb {
  position: absolute; top: 9px; right: 9px;
  font-size: 10.5px; font-weight: 900;
  padding: 3px 8px; border-radius: 6px; z-index: 2;
  line-height: 1.5; letter-spacing: .03em;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
[dir=ltr] .cb { right: auto; left: 9px; }
.cb-deal  { background: linear-gradient(135deg, #FF2D2D, #FF6A00); color: #fff; }
.cb-sale  { background: var(--pr); color: #fff; }
.cb-trend { background: linear-gradient(135deg, #7B2FBE, #0EA5E9); color: #fff; }
.cb-best  { background: linear-gradient(135deg, #854D0E, #F59E0B); color: #fff; }
.cb-new   { background: linear-gradient(135deg, #0369A1, #06B6D4); color: #fff; }

/* Overlay actions */
.pc-ov {
  position: absolute; top: 9px; left: 9px;
  display: flex; flex-direction: column; gap: 6px;
  opacity: 0; transition: opacity .18s; z-index: 3;
  pointer-events: none;
}
[dir=ltr] .pc-ov { left: auto; right: 9px; }
.pc:hover .pc-ov { opacity: 1; pointer-events: auto; }
.pc-ov-btn {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(0,0,0,.08);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: #555; transition: all .16s;
  box-shadow: 0 2px 8px rgba(0,0,0,.14);
}
.pc-ov-btn:hover { background: var(--pr); color: #fff; border-color: var(--pr); transform: scale(1.12); }

/* Card body */
.pc-body { padding: 11px 12px 13px; }
.pc-name {
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; font-size: 12.5px; font-weight: 600; color: var(--t1);
  line-height: 1.4; margin-bottom: 7px; text-decoration: none;
  transition: color .14s;
}
.pc-name:hover { color: var(--pr); }
.pc-meta { margin-bottom: 5px; }
.pc-stars { display: flex; align-items: center; gap: 2px; }
.sf { color: #F59E0B; font-size: 11px; }
.sh { color: #F59E0B; font-size: 11px; opacity: .5; }
.se { color: #DDD; font-size: 11px; }
.pc-rv { font-size: 11px; font-weight: 700; color: #F59E0B; margin-inline-start: 3px; }
.pc-rc { font-size: 10.5px; color: var(--t3); }
.pc-price { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; margin-bottom: 5px; }
.cp-now  { font-size: 17px; font-weight: 900; color: var(--pr); }
.cp-old  { font-size: 12px; color: var(--t3); text-decoration: line-through; }
.cp-pct  {
  font-size: 10.5px; font-weight: 800; color: var(--pr);
  background: rgba(255,45,45,.1); padding: 1px 6px; border-radius: 4px;
  font-style: normal;
}
/* Social proof inside card */
.csoc {
  font-size: 11px; color: var(--t3); margin-bottom: 6px;
  display: flex; align-items: center; gap: 4px; font-weight: 600;
}
.csoc.hot { color: #B45309; }
.csoc.urg { color: var(--pr); }

/* Add to cart */
.pc-foot { display: flex; gap: 7px; align-items: center; }
.pc-atc {
  flex: 1; padding: 8px 6px;
  background: linear-gradient(135deg, #FF2D2D, #FF6A00);
  color: #fff; border: none; border-radius: 7px;
  font-weight: 800; font-size: 11.5px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 5px;
  transition: all .18s; font-family: inherit;
  box-shadow: 0 3px 12px rgba(255,45,45,.30);
}
.pc-atc:hover { filter: brightness(1.1); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(255,45,45,.45); }
.pc-wl {
  width: 34px; height: 34px; border-radius: 7px;
  background: var(--pr-bg); border: 1px solid rgba(255,45,45,.15);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .18s; flex-shrink: 0;
}
.pc-wl:hover { background: var(--pr); }
.pc-wl:hover svg { stroke: #fff !important; }
.pc-wl.on { background: var(--pr); }
.pc-wl.on svg { stroke: #fff !important; fill: #fff !important; }

.prd-tab-pane { display: none !important; }
.prd-tab-pane.active { display: grid !important; }

/* Grid layout */
.prd-grid-5 {
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
@media(max-width:1100px) { .prd-grid-5 { grid-template-columns: repeat(4,1fr); } }
@media(max-width:840px)  { .prd-grid-5 { grid-template-columns: repeat(3,1fr); } }
@media(max-width:580px)  { .prd-grid-5 { grid-template-columns: repeat(2,1fr); gap: 9px; } }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   12. PRODUCT TABS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.prd-tabs {
  display: flex; gap: 2px;
  background: #fff;
  border: 1px solid var(--bd);
  border-radius: 10px; padding: 4px;
  margin-bottom: 18px;
  width: fit-content;
}
.prd-tab-btn {
  padding: 8px 20px; border: none; background: none;
  cursor: pointer; font-size: 13px; font-weight: 700;
  color: var(--t2); border-radius: 7px;
  transition: all .18s; font-family: inherit; white-space: nowrap;
}
.prd-tab-btn:hover { color: var(--pr); background: rgba(255,45,45,.06); }
.prd-tab-btn.active {
  background: var(--pr);
  color: #fff;
  box-shadow: 0 3px 12px rgba(255,45,45,.35);
}
.prd-tab-pane { display: none; }
.prd-tab-pane.active { display: grid; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   13. PARTNER LOGOS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-partners-sec { background: #fff; padding: 32px 0; }
.ch-partners-grid {
  display: grid !important;
  grid-template-columns: repeat(5, 1fr) !important;
  gap: 14px; margin-top: 22px;
}
@media(max-width:900px) { .ch-partners-grid { grid-template-columns: repeat(3,1fr) !important; } }
@media(max-width:500px) { .ch-partners-grid { grid-template-columns: repeat(2,1fr) !important; } }
.ch-partner-card {
  background: #fff !important;
  border: 1px solid var(--bd) !important;
  border-radius: 14px !important;
  padding: 0 0 14px !important;
  display: flex !important; flex-direction: column !important;
  align-items: center !important; gap: 10px !important;
  overflow: hidden; transition: all .22s; opacity: 1 !important;
}
.ch-partner-card:hover {
  border-color: var(--pr) !important;
  box-shadow: 0 8px 28px rgba(255,45,45,.10) !important;
  transform: translateY(-4px) !important;
}
.ch-pc-logo { width: 100%; height: 60px; display: flex; align-items: center; justify-content: center; }
.ch-pc-name { font-size: 11px; font-weight: 700; color: var(--t1); padding: 0 8px; text-align: center; }
.ch-pc-tag { font-size: 10px; font-weight: 700; padding: 3px 10px; border-radius: 99px; }
.ch-tag-cn     { background: rgba(255,45,45,.08); color: var(--pr); }
.ch-tag-global { background: rgba(0,192,106,.1);  color: var(--green); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   14. WHY CHINAHUB
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-why-sec { background: var(--bg); padding: 0; }
.ch-why-grid {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 14px;
}
@media(max-width:768px){ .ch-why-grid { grid-template-columns: repeat(2,1fr) !important; } }
@media(max-width:480px){ .ch-why-grid { grid-template-columns: 1fr !important; } }
.ch-why-card {
  background: #fff; border: 1px solid var(--bd);
  border-radius: 14px; padding: 24px 20px;
  transition: all .22s; position: relative; overflow: hidden;
}
.ch-why-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 3px; opacity: 0; transition: opacity .22s;
  background: linear-gradient(90deg, var(--pr), var(--gd));
}
.ch-why-card:hover { border-color: var(--pr); box-shadow: 0 10px 36px rgba(255,45,45,.10); transform: translateY(-4px); }
.ch-why-card:hover::before { opacity: 1; }
.ch-why-icon-wrap {
  width: 52px; height: 52px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; margin-bottom: 14px;
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}
.ch-why-ttl { font-size: 15px; font-weight: 800; color: var(--t1); margin-bottom: 6px; }
.ch-why-sub { font-size: 12.5px; color: var(--t3); line-height: 1.6; margin-bottom: 10px; }
.ch-why-stat { font-size: 11px; font-weight: 800; color: var(--pr); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   15. REVIEWS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-reviews-grid {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 14px !important;
}
@media(max-width:768px){ .ch-reviews-grid { grid-template-columns: repeat(2,1fr) !important; } }
@media(max-width:480px){ .ch-reviews-grid { grid-template-columns: 1fr !important; } }
.ch-review-card {
  background: #fff; border: 1px solid var(--bd);
  border-radius: 14px; padding: 18px 16px;
  transition: all .2s;
}
.ch-review-card:hover { border-color: var(--pr); box-shadow: 0 8px 28px rgba(255,45,45,.08); }
.ch-review-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.ch-review-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 15px; flex-shrink: 0;
}
.ch-review-name { font-size: 13px; font-weight: 700; color: var(--t1); }
.ch-review-stars { margin-inline-start: auto; color: #F59E0B; font-size: 12px; }
.ch-review-text { font-size: 12.5px; color: var(--t2); line-height: 1.65; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   16. STATS ROW
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-stats-row {
  display: grid !important;
  grid-template-columns: repeat(4,1fr) !important;
  gap: 14px; padding: 4px 0;
}
@media(max-width:600px) { .ch-stats-row { grid-template-columns: repeat(2,1fr) !important; } }
.ch-stat-box {
  background: #fff; border: 1px solid var(--bd);
  border-radius: 16px; padding: 28px 16px;
  text-align: center; transition: all .22s;
  position: relative; overflow: hidden;
}
.ch-stat-box::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--pr), var(--gd));
}
.ch-stat-box:hover { border-color: var(--pr); box-shadow: 0 10px 36px rgba(255,45,45,.10); transform: translateY(-4px); }
.ch-stat-num { font-size: 32px !important; font-weight: 900 !important; color: var(--pr) !important; margin-bottom: 6px !important; }
.ch-stat-lbl { font-size: 13px; color: var(--t2); font-weight: 600; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   17. FLAGS TICKER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-flags-sec { background: #fff; border-top: 1px solid var(--bd); border-bottom: 1px solid var(--bd); padding: 14px 0; overflow: hidden; }
.ch-flags-ticker { overflow: hidden; position: relative; padding: 4px 0; }
.ch-flags-ticker::before,
.ch-flags-ticker::after { content: ''; position: absolute; top: 0; bottom: 0; width: 80px; z-index: 2; pointer-events: none; }
.ch-flags-ticker::before { left: 0;  background: linear-gradient(90deg, #fff, transparent); }
.ch-flags-ticker::after  { right: 0; background: linear-gradient(270deg, #fff, transparent); }
.ch-flags-track { display: flex; gap: 8px; animation: flagScroll 40s linear infinite; width: max-content; }
.ch-flags-track:hover { animation-play-state: paused; }
@keyframes flagScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
[dir=rtl] .ch-flags-track { animation-direction: reverse; }
.ch-flag-item {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 99px;
  background: #F5F5F8; border: 1px solid var(--bd);
  white-space: nowrap; transition: all .18s;
}
.ch-flag-item:hover { background: rgba(255,45,45,.07); border-color: var(--pr); }
.ch-flag-emoji { font-size: 16px; }
.ch-flag-name { font-size: 11px; font-weight: 600; color: var(--t2); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   18. CTA SECTION
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-cta-sec {
  background: linear-gradient(135deg, #0A0E1A 0%, #111827 40%, #0A1525 100%);
  padding: 60px 0; position: relative; overflow: hidden;
}
.ch-cta-sec::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 600px 400px at 20% 50%, rgba(255,45,45,.15) 0%, transparent 55%),
    radial-gradient(ellipse 400px 300px at 80% 30%, rgba(255,184,0,.08) 0%, transparent 50%);
}
.ch-cta-sec::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: linear-gradient(90deg, transparent, var(--pr), var(--gd), var(--pr), transparent);
}
.ch-cta-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 36px; flex-wrap: wrap; position: relative; z-index: 1;
}
.ch-cta-h { font-size: 30px; font-weight: 900; color: #fff; margin-bottom: 10px; letter-spacing: -.5px; }
.ch-cta-p { font-size: 14.5px; color: rgba(255,255,255,.58); line-height: 1.8; }
.ch-cta-btns { display: flex; gap: 12px; flex-wrap: wrap; flex-shrink: 0; }
.ch-cta-btn {
  background: linear-gradient(135deg, var(--pr), #FF6A00);
  color: #fff; padding: 14px 36px; border-radius: 9px;
  font-weight: 900; font-size: 15px; text-decoration: none;
  box-shadow: 0 6px 28px rgba(255,45,45,.50); transition: all .2s;
  display: inline-block; white-space: nowrap;
}
.ch-cta-btn:hover { transform: translateY(-3px); box-shadow: 0 12px 40px rgba(255,45,45,.65); }
.ch-cta-btn-ghost {
  background: rgba(255,255,255,.08); border: 1.5px solid rgba(255,255,255,.28);
  color: #fff; padding: 12px 26px; border-radius: 9px;
  font-weight: 700; font-size: 14px; text-decoration: none;
  display: inline-block; transition: all .2s; white-space: nowrap;
}
.ch-cta-btn-ghost:hover { background: rgba(255,255,255,.16); transform: translateY(-3px); }
.ch-btn-white { background: #fff; color: var(--pr) !important; font-weight: 900; padding: 13px 28px; border-radius: 8px; text-decoration: none; font-size: 14.5px; transition: all .2s; display: inline-block; box-shadow: 0 4px 18px rgba(255,255,255,.2); }
.ch-btn-white:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(255,255,255,.3); }
.ch-btn-dark { background: rgba(255,255,255,.1); border: 1.5px solid rgba(255,255,255,.28); color: #fff !important; font-weight: 700; padding: 12px 24px; border-radius: 8px; text-decoration: none; font-size: 14px; transition: all .2s; display: inline-block; }
.ch-btn-dark:hover { background: rgba(255,255,255,.18); transform: translateY(-2px); }
@media(max-width:768px) { .ch-cta-inner { flex-direction: column; text-align: center; } .ch-cta-btns { justify-content: center; } .ch-cta-h { font-size: 24px; } }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   19. FOOTER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-footer { background: var(--nv) !important; }
.ch-footer-top { border-bottom: 1px solid rgba(255,255,255,.07); }
.ch-footer-h { color: #fff !important; font-weight: 800 !important; font-size: 14px; }
.ch-footer-link { color: rgba(255,255,255,.48) !important; }
.ch-footer-link:hover { color: var(--gd) !important; }
.ch-footer-bottom { background: rgba(0,0,0,.30); border-top: 1px solid rgba(255,255,255,.06); }
.ch-footer-copy { color: rgba(255,255,255,.38); font-size: 12px; }
.ch-footer-logo-txt { font-size: 26px; font-weight: 900; }
.ch-footer-logo-txt b { color: var(--pr) !important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   20. MISCELLANEOUS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* Scroll top */
#ch-scroll-top { background: var(--pr) !important; box-shadow: 0 4px 18px rgba(255,45,45,.45) !important; }
#ch-scroll-top:hover { background: var(--pr-d) !important; transform: translateY(-2px) !important; }

/* WhatsApp float */
.ch-wa-float {
  position: fixed; bottom: 80px; left: 24px;
  width: 54px; height: 54px;
  background: #25D366; color: #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 22px rgba(37,211,102,.55); z-index: 999;
  transition: all .22s; text-decoration: none;
}
[dir=rtl] .ch-wa-float { left: auto; right: 24px; }
.ch-wa-float:hover { transform: scale(1.12); box-shadow: 0 8px 36px rgba(37,211,102,.7); }
.ch-wa-float::before { content: ''; position: absolute; inset: -6px; border-radius: 50%; border: 2px solid rgba(37,211,102,.38); animation: wap 2.2s ease-in-out infinite; }
@keyframes wap { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.2);opacity:0} }

/* Reveal animation */
.ch-reveal { opacity: 1 !important; transform: none !important; }

/* Search suggestions */
.ch-sug-price { color: var(--pr) !important; font-weight: 700; }
.ch-sug-item:hover { background: rgba(255,45,45,.05); }
.ch-sug-keywords span:hover { border-color: var(--pr) !important; color: var(--pr) !important; }

/* Section gap */
.ch-section-gap { margin-top: 36px !important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   21. GLOBAL INTERACTIVE POLISH
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* Smooth all links */
a { transition: color .15s ease, opacity .15s ease; }

/* Focus rings — accessibility */
:focus-visible { outline: 2px solid var(--pr); outline-offset: 2px; }

/* Thin scrollbar */
* { scrollbar-width: thin; scrollbar-color: var(--pr) transparent; }
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-thumb { background: var(--pr); border-radius: 99px; }
::-webkit-scrollbar-track { background: transparent; }

/* Selection color */
::selection { background: rgba(255,45,45,.2); color: var(--t1); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   22. MOBILE RESPONSIVE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media(max-width:768px) {
  .hero-inner { grid-template-columns: 1fr; min-height: auto; padding: 36px 0; gap: 28px; }
  .hero-img { display: none; }
  .hero-h { font-size: 26px; }
  .hero-stats { grid-template-columns: repeat(2,1fr); }
  .flash-hd { padding: 12px 16px; }
  .flash-cd span:not(.flash-cd-sep) { font-size: 16px; min-width: 34px; padding: 4px 8px; }
  .flash-more { padding: 7px 15px; font-size: 11.5px; }
  .prd-tabs { width: auto; overflow-x: auto; }
  .prd-tab-btn { padding: 7px 14px; font-size: 12px; }
}
@media(max-width:480px) {
  .flash-grid { grid-template-columns: repeat(2,1fr); }
  .flash-card { border-inline-end: none; border-bottom: 1px solid rgba(255,255,255,.05); }
  .flash-cd-wrap { display: none; }
}
