/*
Theme Name:  USPowders v6
Theme URI:   https://uspowders.com
Author:      USPowders.com
Description: Clean white clinical theme — bright, modern, copper accents, full WooCommerce integration. Bulk peptide supplier. v6.
Version:     6.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License:     GPL-2.0-or-later
Text Domain: uspowders
*/

/* ============================================================
   TOKENS — CLEAN WHITE
   ============================================================ */
:root {
  /* Backgrounds */
  --black:       #ffffff;
  --s1:          #f8f9fb;
  --s2:          #ffffff;
  --s3:          #f2f4f7;
  --s4:          #eaecf0;
  --s5:          #e0e3e8;

  /* Copper / Brand */
  --copper:      #b86e2a;
  --copper-l:    #c97c3a;
  --copper-ll:   #e09050;
  --copper-d:    #8b5522;
  --gold:        #b8962a;
  --gold-l:      #c9a840;

  /* Text */
  --cream:       #0a0a0f;
  --cream-d:     #2a2a35;
  --muted:       #9098a8;
  --muted-l:     #5a6478;

  /* Borders */
  --border:      rgba(180,100,40,0.18);
  --border-d:    #e4e7ed;

  /* Copper tints */
  --copper-bg:   rgba(180,100,40,0.06);
  --copper-bg2:  rgba(180,100,40,0.10);
  --green:       #1e9e5e;

  --serif:   'Playfair Display', Georgia, serif;
  --sans:    'Jost', system-ui, sans-serif;
  --mono:    'JetBrains Mono', monospace;

  --r-sm:  4px;
  --r-md:  8px;
  --r-lg:  12px;
  --r-xl:  16px;
  --r-pill:100px;

  --ease:  cubic-bezier(0.16,1,0.3,1);
  --fast:  0.15s;
  --med:   0.28s;

  --max:   1240px;
  --pad:   clamp(20px,4vw,48px);
}

/* ============================================================
   RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  background: #f8f9fb;
  color: #1a1f2e;
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
  width: 100%;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--copper); text-decoration: none; }
a:hover { color: var(--copper-d); }
ul, ol { list-style: none; }
button, input, textarea, select { font-family: inherit; }
::selection { background: var(--copper); color: #fff; }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: #f0f2f5; }
::-webkit-scrollbar-thumb { background: var(--copper-d); border-radius: 3px; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6 { font-family: var(--serif); font-weight: 300; line-height: 1.1; color: #0a0a14; letter-spacing: -.02em; }
h1 { font-size: clamp(3rem,5.5vw,6rem); }
h2 { font-size: clamp(2rem,3.5vw,3.2rem); }
h3 { font-size: clamp(1.3rem,2vw,1.8rem); }
h4 { font-size: 1.1rem; font-family: var(--sans); font-weight: 500; letter-spacing: 0; }
p  { color: #5a6478; line-height: 1.85; margin-bottom: 1.2rem; }
p:last-child { margin-bottom: 0; }

.eyebrow {
  display: block;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--copper);
  margin-bottom: 12px;
}
.text-shine {
  background: linear-gradient(135deg,#c07b3a 0%,#dfc06a 40%,#c07b3a 70%,#8b5522 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shine 4s linear infinite;
}
@keyframes shine { to { background-position: 200% center; } }

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.wrap--wide { max-width: 1400px; }
.section { padding: clamp(60px,8vw,100px) var(--pad); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 28px;
  font-family: var(--sans); font-size: 10px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  border: none; border-radius: var(--r-sm); cursor: pointer;
  transition: all var(--med) var(--ease);
  white-space: nowrap; text-decoration: none;
}
.btn-primary {
  background: linear-gradient(135deg,var(--copper),var(--copper-d));
  color: #fff;
  box-shadow: 0 8px 28px rgba(192,123,58,.28);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(192,123,58,.4); color: #fff; }
.btn-outline {
  background: transparent;
  border: 1px solid rgba(192,123,58,.3);
  color: var(--copper-l);
}
.btn-outline:hover { border-color: var(--copper); background: var(--copper-bg); transform: translateY(-2px); color: var(--copper-ll); }
.btn-sm { padding: 8px 18px; font-size: 9px; }
.btn-lg { padding: 16px 36px; font-size: 11px; }
.btn-block { width: 100%; justify-content: center; }

/* ============================================================
   UTILITY BAR
   ============================================================ */
#ubar {
  background: #0a0a14;
  border-bottom: none;
  padding: 8px var(--pad);
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; flex-wrap: wrap;
  font-size: 10px; letter-spacing: .2em; text-transform: uppercase;
  color: #6b5f52; width: 100%;
}
#ubar .ub-sep { color: var(--copper); margin: 0 6px; }
#ubar .ub-right { display: flex; gap: 20px; }
#ubar .ub-right a { color: #6b5f52; transition: color var(--fast); }
#ubar .ub-right a:hover { color: var(--copper); }

/* ============================================================
   HEADER / NAV
   ============================================================ */
#site-header {
  position: sticky;
  top: 0; left: 0; right: 0;
  width: 100%;
  z-index: 200;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(24px) saturate(1.4);
  border-bottom: 1px solid var(--border-d);
  transition: box-shadow var(--med);
}
#site-header.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,.08); }

.header-inner {
  max-width: var(--max); margin: 0 auto; padding: 0 var(--pad);
  display: flex; align-items: center; justify-content: space-between;
  height: 68px; gap: 24px;
}

/* Logo */
.site-logo { display: flex; align-items: center; gap: 12px; text-decoration: none; flex-shrink: 0; }
.logo-mark {
  width: 36px; height: 36px;
  background: linear-gradient(135deg,var(--copper),var(--copper-d));
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 16px; font-weight: 500; color: #fff;
  box-shadow: 0 4px 16px rgba(192,123,58,.3);
}
.logo-name {
  font-family: var(--serif); font-size: 20px; font-weight: 400;
  letter-spacing: .1em; color: var(--cream);
}
.logo-name em { color: var(--copper); font-style: normal; }

/* Primary nav */
#primary-nav {
  display: flex; align-items: center; gap: 2px; flex: 1; justify-content: center;
}
#primary-nav a {
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: #7a8090; padding: 8px 13px; border-radius: var(--r-sm);
  transition: all var(--fast); font-weight: 400; white-space: nowrap;
}
#primary-nav a:hover { color: #0a0a14; background: #f2f4f7; }
#primary-nav .current-menu-item a,
#primary-nav .current_page_item a,
#primary-nav a.active { color: var(--copper); }

/* Header actions */
.header-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.hdr-icon {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid transparent; border-radius: var(--r-sm);
  color: #7a8090; cursor: pointer; transition: all var(--fast);
  background: transparent; text-decoration: none; position: relative;
}
.hdr-icon:hover { border-color: #e4e7ed; color: var(--copper); background: #f8f9fb; }
.hdr-cart-count {
  position: absolute; top: -4px; right: -4px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--copper); color: #fff;
  font-size: 9px; font-weight: 600; display: flex; align-items: center; justify-content: center;
}

/* Mobile toggle */
.mob-toggle {
  display: none; flex-direction: column; gap: 5px;
  width: 36px; height: 36px; align-items: center; justify-content: center;
  background: transparent; border: 1px solid #e4e7ed; border-radius: var(--r-sm);
  cursor: pointer;
}
.mob-toggle span { width: 18px; height: 1.5px; background: #5a6478; border-radius: 2px; transition: all var(--med); }

/* Mobile nav overlay */
.mob-nav {
  display: none; position: fixed; inset: 0;
  background: rgba(255,255,255,.98); backdrop-filter: blur(24px);
  z-index: 300; flex-direction: column; align-items: center; justify-content: center; gap: 28px;
}
.mob-nav.open { display: flex; }
.mob-nav a { font-family: var(--serif); font-size: 2.2rem; font-weight: 300; color: var(--cream); transition: color var(--fast); }
.mob-nav a:hover { color: var(--copper); }
.mob-close {
  position: absolute; top: 20px; right: 20px;
  background: none; border: none; color: #9098a8; cursor: pointer;
  width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; font-size: 24px;
}

/* Search overlay */
#search-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(255,255,255,.97); backdrop-filter: blur(24px);
  z-index: 400; align-items: center; justify-content: center;
}
#search-overlay.open { display: flex; }
#search-overlay form { width: 100%; max-width: 600px; padding: 0 24px; position: relative; }
#search-overlay input[type="search"] {
  width: 100%; padding: 18px 56px 18px 24px;
  background: #fff; border: 2px solid #e4e7ed;
  border-radius: var(--r-sm); color: #0a0a14; font-size: 1.2rem;
  font-family: var(--serif); font-weight: 300; outline: none;
}
#search-overlay input[type="search"]::placeholder { color: #b0b8c8; }
.search-close {
  position: absolute; top: 20px; right: 44px;
  background: none; border: none; color: #9098a8; cursor: pointer; font-size: 20px;
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  min-height: 100vh; width: 100%;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: clamp(100px,14vw,160px) var(--pad) 80px;
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(135deg, #f8f9fb 0%, #f0f4f8 100%);
}
.hero-grid {
  position: absolute; inset: 0; z-index: 0; opacity: .04;
  background-image: linear-gradient(rgba(180,100,40,.08) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(180,100,40,.08) 1px, transparent 1px);
  background-size: 60px 60px;
}
.hero-inner {
  position: relative; z-index: 1;
  max-width: var(--max); margin: 0 auto; width: 100%;
  display: grid; grid-template-columns: 1fr 340px; gap: 60px; align-items: center;
}
.hero-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px;
  background: rgba(192,123,58,.08); border: 1px solid rgba(192,123,58,.25);
  border-radius: var(--r-pill);
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--copper-l); margin-bottom: 28px;
}
.pill-dot {
  width: 5px; height: 5px; background: var(--copper); border-radius: 50%;
  animation: blink 2.2s ease-in-out infinite;
}
@keyframes blink { 0%,100% { opacity:1; } 50% { opacity:.3; } }

.hero h1 { margin-bottom: 20px; }
.hero-desc {
  font-size: 1.05rem; color: var(--muted-l); line-height: 1.85;
  max-width: 500px; margin-bottom: 36px; font-weight: 300;
}
.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 56px; }
.hero-stats {
  display: flex; gap: 36px; padding-top: 36px;
  border-top: 1px solid var(--border-d); flex-wrap: wrap;
}
.stat-val {
  font-family: var(--serif); font-size: 2.2rem; font-weight: 300;
  color: #0a0a14; display: block; line-height: 1; margin-bottom: 6px;
}
.stat-lbl { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: #b0b8c8; }

/* Hero compound cards */
.hero-compounds { display: flex; flex-direction: column; gap: 10px; }
.hc-card {
  background: #fff; border: 1px solid #e4e7ed;
  border-radius: var(--r-lg); padding: 16px 20px; cursor: pointer;
  transition: all var(--med) var(--ease);
}
.hc-card:hover, .hc-card.featured { border-color: rgba(180,100,40,.25); background: rgba(180,100,40,.05); }
.hc-name { font-family: var(--mono); font-size: 13px; color: var(--copper); margin-bottom: 4px; }
.hc-inci { font-size: 10px; color: var(--muted); letter-spacing: .05em; margin-bottom: 10px; }
.hc-purity { display: flex; align-items: center; gap: 5px; font-size: 10px; color: var(--green); letter-spacing: .1em; text-transform: uppercase; }
.hc-dot { width: 5px; height: 5px; background: var(--green); border-radius: 50%; }

/* ============================================================
   TICKER
   ============================================================ */
.ticker-wrap {
  background: #0a0a14; overflow: hidden;
  border-top: none; border-bottom: none;
  padding: 12px 0; width: 100%;
}
.ticker-track { display: flex; gap: 48px; animation: ticker 28s linear infinite; width: max-content; }
.ticker-track:hover { animation-play-state: paused; }
@keyframes ticker { to { transform: translateX(-50%); } }
.tick-item {
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--muted); white-space: nowrap; display: flex; align-items: center; gap: 10px;
}
.tick-item::after { content: '◆'; color: var(--copper); font-size: 6px; }

/* ============================================================
   FEATURE STRIP
   ============================================================ */
.feature-strip {
  display: grid; grid-template-columns: repeat(4,1fr);
  border-top: none; border-bottom: none;
  width: 100%;
}
.fi {
  padding: 28px 28px; display: flex; align-items: center; gap: 16px;
  border-right: 1px solid var(--border-d); background: #fff;
  transition: background var(--fast);
}
.fi:last-child { border-right: none; }
.fi:hover { background: #f8f9fb; }
.fi-icon {
  width: 40px; height: 40px; flex-shrink: 0;
  background: rgba(192,123,58,.1); border: 1px solid rgba(192,123,58,.2);
  border-radius: var(--r-md); display: flex; align-items: center; justify-content: center;
  color: var(--copper);
}
.fi-title { font-size: 13px; font-weight: 500; color: var(--cream); margin-bottom: 3px; font-family: var(--sans); }
.fi-sub { font-size: 11px; color: #b0b8c8; }

/* ============================================================
   COMPOUND CARDS (home + archive)
   ============================================================ */
.compounds-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px;
}
.cpd-card {
  background: #fff; border: 1px solid #e4e7ed;
  border-radius: var(--r-xl); overflow: hidden; cursor: pointer;
  transition: all var(--med) var(--ease);
}
.cpd-card:hover {
  border-color: rgba(180,100,40,.3);
  transform: translateY(-5px);
  box-shadow: 0 24px 60px rgba(0,0,0,.45);
}
.cpd-img {
  height: 180px; position: relative; overflow: hidden;
  background: linear-gradient(135deg,#f2f4f7,#eaecf0);
  display: flex; align-items: center; justify-content: center;
}
.cpd-img-glow {
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 50%,rgba(180,100,40,.1) 0%,transparent 70%);
}
.cpd-mol {
  font-family: var(--mono); font-size: 52px; color: var(--copper);
  opacity: .15; letter-spacing: -.05em; z-index: 1; position: relative;
}
.cpd-cat {
  position: absolute; top: 12px; left: 12px;
  background: rgba(192,123,58,.15); border: 1px solid rgba(192,123,58,.3);
  border-radius: var(--r-pill); font-size: 9px; letter-spacing: .15em;
  text-transform: uppercase; color: var(--copper-l); padding: 4px 10px;
}
.cpd-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.cpd-card:hover .cpd-img img { transform: scale(1.06); }
.cpd-body { padding: 20px 24px; }
.cpd-code { font-family: var(--mono); font-size: 12px; color: var(--copper-l); margin-bottom: 6px; }
.cpd-name { font-size: 15px; font-weight: 500; color: #0a0a14; margin-bottom: 8px; line-height: 1.3; font-family: var(--sans); }
.cpd-desc { font-size: 12px; color: var(--muted); line-height: 1.75; margin-bottom: 18px; }
.cpd-footer { display: flex; align-items: center; justify-content: space-between; }
.cpd-purity { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--green); display: flex; align-items: center; gap: 5px; }
.cpd-purity-dot { width: 5px; height: 5px; background: var(--green); border-radius: 50%; }
.cpd-cta { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--copper); transition: color var(--fast); }
.cpd-cta:hover { color: var(--copper-ll); }

/* ============================================================
   LOT SIZE SELECTOR
   ============================================================ */
.lot-section { background: #f8f9fb; border-top: none; border-bottom: none; }
.lot-inner {
  max-width: var(--max); margin: 0 auto; padding: clamp(60px,8vw,100px) var(--pad);
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.lot-spec { display: flex; align-items: flex-start; gap: 10px; font-size: 12px; color: var(--cream-d); margin-bottom: 12px; }
.lot-spec svg { color: var(--copper); flex-shrink: 0; margin-top: 1px; }

.lot-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 16px; }
.lot-btn {
  background: #fff; border: 1px solid #e4e7ed;
  border-radius: var(--r-md); padding: 18px 10px; text-align: center;
  cursor: pointer; transition: all var(--fast); position: relative;
  font-family: inherit;
}
.lot-btn:hover { border-color: rgba(180,100,40,.35); background: rgba(180,100,40,.06); }
.lot-btn.active {
  border-color: rgba(180,100,40,.5);
  background: rgba(180,100,40,.08);
  box-shadow: 0 0 0 1px rgba(180,100,40,.4);
}
.lot-sz { font-family: var(--mono); font-size: 16px; color: #0a0a14; display: block; }
.lot-btn.active .lot-sz { color: var(--copper); }
.lot-badge {
  position: absolute; top: -8px; left: 50%; transform: translateX(-50%);
  background: var(--copper-d); border-radius: var(--r-pill);
  font-size: 8px; letter-spacing: .12em; text-transform: uppercase;
  color: #fff; padding: 2px 8px; white-space: nowrap; font-family: var(--sans); font-weight: 500;
}
.lot-badge.pop { background: var(--gold); color: var(--black); }
.lot-notice {
  display: none; align-items: flex-start; gap: 8px;
  padding: 12px 16px; margin-top: 12px;
  background: rgba(180,100,40,.06); border: 1px solid rgba(180,100,40,.2);
  border-radius: var(--r-sm); font-size: 11px; letter-spacing: .06em; color: var(--copper-l);
}
.lot-notice.show { display: flex; }

/* ============================================================
   BULK SECTION
   ============================================================ */
.bulk-section { background: #fff; border-top: 1px solid #e4e7ed; }
.bulk-banner {
  background: linear-gradient(135deg,rgba(180,100,40,.06),rgba(201,168,76,.03));
  border: 1px solid rgba(180,100,40,.2);
  border-radius: var(--r-xl); padding: clamp(32px,4vw,56px);
  display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
  position: relative; overflow: hidden;
}
.bulk-banner::before {
  content: 'BULK';
  position: absolute; right: 40px; top: 50%; transform: translateY(-50%);
  font-family: var(--serif); font-size: clamp(80px,12vw,150px); font-weight: 300;
  color: rgba(192,123,58,.05); letter-spacing: -.05em; pointer-events: none; line-height: 1;
}
.bulk-title { font-family: var(--serif); font-size: clamp(1.8rem,3vw,2.6rem); font-weight: 300; color: var(--cream); margin-bottom: 12px; line-height: 1.15; }
.bulk-desc { font-size: 14px; color: var(--muted-l); line-height: 1.85; max-width: 500px; margin-bottom: 24px; }
.bulk-specs { display: flex; flex-wrap: wrap; gap: 14px 28px; }
.bspec { display: flex; align-items: center; gap: 7px; font-size: 11px; color: #2a2a35; }
.bspec svg { color: var(--copper); flex-shrink: 0; }
.bulk-ctas { display: flex; flex-direction: column; gap: 10px; flex-shrink: 0; min-width: 180px; }

/* ============================================================
   COA PANEL (product page + standalone)
   ============================================================ */
.coa-wrap { margin: 48px 0; }
.coa-panel {
  background: #fff; border: 1px solid rgba(180,100,40,.2);
  border-radius: var(--r-xl); overflow: hidden;
}
.coa-header {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 20px 28px; flex-wrap: wrap;
  background: rgba(180,100,40,.04); border-bottom: 1px solid #eee;
}
.coa-header-l { display: flex; align-items: center; gap: 14px; }
.coa-icon {
  width: 42px; height: 42px; flex-shrink: 0;
  background: rgba(180,100,40,.08); border: 1px solid rgba(180,100,40,.2);
  border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; color: var(--copper);
}
.coa-title { font-size: 15px; font-weight: 500; color: #0a0a14; font-family: var(--sans); margin-bottom: 2px; }
.coa-sub { font-size: 11px; color: #b0b8c8; }
.coa-dl {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 18px; background: rgba(180,100,40,.06);
  border: 1px solid rgba(180,100,40,.22); border-radius: var(--r-sm);
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--copper-l);
  transition: all var(--fast); cursor: pointer; font-family: var(--sans);
}
.coa-dl:hover { background: rgba(192,123,58,.15); color: var(--copper-ll); }
.coa-grid { display: grid; grid-template-columns: 1fr 1fr; }
.coa-row {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 13px 28px; border-bottom: 1px solid #f0f2f5;
}
.coa-row:nth-child(odd) { background: rgba(0,0,0,.02); }
.coa-lbl { font-family: var(--sans); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: #b0b8c8; }
.coa-val { font-family: var(--mono); font-size: 13px; color: #2a2a35; }
.coa-val.hi { color: var(--gold-l); display: flex; align-items: center; gap: 8px; }
.pass { background: rgba(58,170,110,.12); border: 1px solid rgba(58,170,110,.25); border-radius: 3px; font-size: 8px; letter-spacing: .14em; text-transform: uppercase; color: var(--green); padding: 2px 6px; font-family: var(--sans); }
.coa-footer { padding: 12px 28px; display: flex; align-items: center; gap: 8px; font-size: 11px; color: var(--muted); background: #f8f9fb; border-top: 1px solid #eee; }

/* ============================================================
   WHO WE SERVE
   ============================================================ */
.serve-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-top: 48px; }
.serve-card {
  background: #fff; border: 1px solid #e4e7ed; border-radius: var(--r-xl);
  padding: 28px 24px; transition: all var(--med) var(--ease); cursor: pointer;
}
.serve-card:hover { border-color: rgba(192,123,58,.28); transform: translateY(-4px); }
.serve-ico {
  width: 38px; height: 38px; background: rgba(192,123,58,.1); border: 1px solid rgba(192,123,58,.2);
  border-radius: var(--r-md); display: flex; align-items: center; justify-content: center;
  color: var(--copper); margin-bottom: 18px;
}
.serve-title { font-size: 14px; font-weight: 500; color: var(--cream); margin-bottom: 8px; font-family: var(--sans); }
.serve-desc { font-size: 12px; color: var(--muted); line-height: 1.75; }

/* ============================================================
   WOOCOMMERCE
   ============================================================ */
/* Remove WC defaults */
.woocommerce-breadcrumb,
.woocommerce-result-count,
.woocommerce-ordering { font-family: var(--sans); }

/* ── Shop page full width layout ── */
.woocommerce .woocommerce-products-header,
.woocommerce-page .woocommerce-products-header { display: none; }

.shop-layout {
  display: block !important;
  width: 100% !important;
}
.shop-main {
  width: 100% !important;
  min-width: 0 !important;
}

/* ── Product grid ── */
ul.products {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0,1fr)) !important;
  gap: 20px !important;
  float: none !important;
  width: 100% !important;
  clear: both !important;
}
ul.products::before,
ul.products::after { display: none !important; }
ul.products.columns-1 { grid-template-columns: 1fr !important; }
ul.products.columns-2 { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
ul.products.columns-3 { grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
ul.products.columns-4 { grid-template-columns: repeat(4, minmax(0,1fr)) !important; }

@media (max-width: 900px) {
  ul.products,
  ul.products.columns-3,
  ul.products.columns-4 { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
}
@media (max-width: 540px) {
  ul.products,
  ul.products.columns-2,
  ul.products.columns-3,
  ul.products.columns-4 { grid-template-columns: 1fr !important; }
}

li.product {
  background: #f8f9fb !important; border: 1px solid #e4e7ed !important;
  border-radius: var(--r-xl) !important; overflow: hidden !important;
  transition: all var(--med) var(--ease) !important;
  margin: 0 !important; float: none !important; width: auto !important; padding: 0 !important;
}
li.product:hover { border-color: rgba(180,100,40,.3) !important; transform: translateY(-5px) !important; box-shadow: 0 24px 60px rgba(0,0,0,.45) !important; }
li.product a.woocommerce-loop-product__link { display: block; text-decoration: none; }
li.product img { width: 100% !important; aspect-ratio: 1; object-fit: cover !important; transition: transform .6s var(--ease); }
li.product:hover img { transform: scale(1.06); }
.woocommerce-loop-product__title {
  font-family: var(--sans) !important; font-size: 14px !important;
  font-weight: 500 !important; color: #0a0a14 !important;
  padding: 16px 20px 4px !important; margin: 0 !important;
}
li.product .price {
  font-family: var(--sans) !important; font-size: 11px !important;
  color: var(--copper) !important; letter-spacing: .14em !important;
  text-transform: uppercase !important; padding: 0 20px 8px !important;
  display: block !important;
}
li.product .add_to_cart_button,
.woocommerce a.button, .woocommerce button.button {
  display: block !important; margin: 0 20px 20px !important;
  padding: 10px 16px !important; text-align: center !important;
  background: transparent !important; border: 1px solid #e4e7ed !important;
  border-radius: var(--r-sm) !important; color: var(--copper-l) !important;
  font-family: var(--sans) !important; font-size: 10px !important;
  font-weight: 500 !important; letter-spacing: .14em !important; text-transform: uppercase !important;
  cursor: pointer !important; transition: all var(--fast) !important;
}
li.product .add_to_cart_button:hover { background: var(--copper) !important; border-color: var(--copper) !important; color: #fff !important; }

/* Single product */
.single-product-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start;
  padding: clamp(60px,8vw,100px) var(--pad);
  max-width: var(--max); margin: 0 auto;
}
.product-gallery { position: sticky; top: 88px; }
.product-gallery .woocommerce-product-gallery { margin: 0 !important; }
.product-gallery .woocommerce-product-gallery__wrapper img { border-radius: var(--r-xl); border: 1px solid #e4e7ed; }

.product-summary h1.product_title { font-size: clamp(1.8rem,3vw,2.8rem); margin-bottom: 8px; }
.product-summary .woocommerce-product-rating { margin-bottom: 16px; }

/* Price contact block */
.usp-price-block {
  background: #fff; border: 1px solid #e4e7ed;
  border-radius: var(--r-lg); padding: 20px 24px; margin: 20px 0;
}
.usp-price-label { font-size: 10px; letter-spacing: .25em; text-transform: uppercase; color: var(--copper); margin-bottom: 14px; display: block; }
.usp-price-ctas { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.usp-price-note { font-size: 12px; color: var(--muted); line-height: 1.7; }

/* Trust badges */
.trust-badges { display: flex; flex-wrap: wrap; gap: 14px; padding: 18px; background: #fff; border: 1px solid #e4e7ed; border-radius: var(--r-lg); margin-top: 20px; }
.trust-badge { display: flex; align-items: center; gap: 6px; font-size: 11px; color: #2a2a35; }
.trust-badge svg { color: var(--copper); }

/* Woo tabs */
.woocommerce-tabs .tabs { border-bottom: 1px solid var(--border-d); display: flex; gap: 0; margin-bottom: 32px; padding: 0; }
.woocommerce-tabs .tabs li { border: none !important; background: none !important; border-radius: 0 !important; }
.woocommerce-tabs .tabs li a {
  font-family: var(--sans); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted); padding: 12px 20px; border-bottom: 2px solid transparent;
  display: block; transition: all var(--fast); font-weight: 400;
}
.woocommerce-tabs .tabs li.active a, .woocommerce-tabs .tabs li a:hover { color: var(--copper-l); border-bottom-color: var(--copper); }

/* Cart / Checkout */
.woocommerce-cart-form table, .shop_table { width: 100%; border-collapse: collapse; }
.woocommerce-cart-form th, .shop_table th { font-family: var(--sans); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); padding: 12px 16px; border-bottom: 1px solid var(--border-d); text-align: left; }
.woocommerce-cart-form td, .shop_table td { padding: 16px; border-bottom: 1px solid rgba(255,255,255,.04); color: var(--cream-d); font-size: 14px; vertical-align: middle; }
.cart-totals, .order-totals { background: #fff; border: 1px solid #e4e7ed; border-radius: var(--r-xl); padding: 28px; }
.woocommerce-billing-fields h3, .woocommerce-shipping-fields h3, #order_review_heading { font-family: var(--sans) !important; font-size: 10px !important; letter-spacing: .25em !important; text-transform: uppercase !important; color: var(--copper) !important; margin-bottom: 20px !important; font-weight: 400 !important; }

/* Notices */
.woocommerce-message { background: rgba(192,123,58,.08); border: 1px solid rgba(192,123,58,.25); color: var(--copper-l); padding: 14px 20px; border-radius: var(--r-sm); margin-bottom: 20px; }
.woocommerce-error { background: rgba(192,57,43,.08); border: 1px solid rgba(192,57,43,.25); color: #e74c3c; padding: 14px 20px; border-radius: var(--r-sm); }

/* Breadcrumb */
.woocommerce-breadcrumb { font-size: 12px !important; color: var(--muted) !important; margin-bottom: 28px !important; font-family: var(--sans) !important; }
.woocommerce-breadcrumb a { color: var(--muted); transition: color var(--fast); }
.woocommerce-breadcrumb a:hover { color: var(--copper); }

/* Pagination */
.woocommerce-pagination { display: flex; justify-content: center; gap: 6px; padding: 48px 0; }
.woocommerce-pagination a, .woocommerce-pagination span { width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; background: #fff; border: 1px solid #e4e7ed; border-radius: var(--r-sm); font-size: 13px; color: var(--muted-l); transition: all var(--fast); }
.woocommerce-pagination a:hover { border-color: var(--copper); color: var(--copper); }
.woocommerce-pagination .current { background: var(--copper); border-color: var(--copper); color: #fff; }

/* ============================================================
   SIDEBAR & WIDGETS
   ============================================================ */
.shop-layout { display: block; width: 100%; }
.shop-main { width: 100%; min-width: 0; }
.sidebar { display: none; }
.widget { background: #fff; border: 1px solid #e4e7ed; border-radius: var(--r-lg); padding: 20px; margin-bottom: 16px; }
.widget-title { font-family: var(--sans); font-size: 10px; letter-spacing: .25em; text-transform: uppercase; color: var(--copper); margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--border-d); font-weight: 400; }
.widget ul li { padding: 8px 0; border-bottom: 1px solid var(--border-d); }
.widget ul li:last-child { border-bottom: none; }
.widget ul li a { font-size: 13px; color: var(--muted-l); display: flex; justify-content: space-between; transition: color var(--fast); }
.widget ul li a:hover { color: var(--copper); }
.widget ul li .count { font-size: 10px; color: var(--muted); background: #f2f4f7; padding: 1px 6px; border-radius: var(--r-pill); }

/* ============================================================
   BLOG
   ============================================================ */
.post-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.post-card { background: #fff; border: 1px solid #e4e7ed; border-radius: var(--r-xl); overflow: hidden; transition: all var(--med) var(--ease); }
.post-card:hover { border-color: rgba(192,123,58,.28); transform: translateY(-4px); box-shadow: 0 20px 50px rgba(0,0,0,.4); }
.post-card-img { aspect-ratio: 16/9; overflow: hidden; background: #f2f4f7; }
.post-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.post-card:hover .post-card-img img { transform: scale(1.05); }
.post-card-body { padding: 20px 24px; }
.post-card-cat { font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--copper); margin-bottom: 8px; display: block; }
.post-card-title { font-size: 15px; font-weight: 500; color: #0a0a14; margin-bottom: 8px; line-height: 1.4; font-family: var(--sans); transition: color var(--fast); }
.post-card:hover .post-card-title { color: var(--copper); }
.post-card-excerpt { font-size: 12px; color: var(--muted); line-height: 1.75; margin-bottom: 14px; }
.post-card-meta { font-size: 10px; color: var(--muted); letter-spacing: .08em; }

.entry-header { padding: clamp(60px,8vw,100px) var(--pad) clamp(32px,4vw,48px); border-bottom: 1px solid var(--border-d); max-width: var(--max); margin: 0 auto; }
.entry-content { max-width: 740px; font-size: 1.05rem; line-height: 1.9; }
.entry-content h2 { font-size: 1.9rem; margin: 3rem 0 1.2rem; }
.entry-content h3 { font-size: 1.4rem; margin: 2.5rem 0 1rem; }
.entry-content p { color: var(--muted-l); }
.entry-content a { color: var(--copper-l); border-bottom: 1px solid rgba(192,123,58,.3); }
.entry-content a:hover { color: var(--gold); border-bottom-color: var(--gold); }
.entry-content blockquote { border-left: 2px solid var(--copper); padding: 16px 24px; margin: 2rem 0; background: #f8f9fb; border-radius: 0 var(--r-sm) var(--r-sm) 0; font-style: italic; color: #2a2a35; }
.entry-content img { border-radius: var(--r-xl); margin: 2rem 0; }
.entry-content code { background: rgba(192,123,58,.1); border: 1px solid rgba(192,123,58,.2); padding: .1em .4em; border-radius: 3px; font-size: .87em; color: var(--copper-ll); font-family: var(--mono); }
.entry-content pre { background: #fff; border: 1px solid #e4e7ed; padding: 24px; border-radius: var(--r-lg); overflow-x: auto; margin: 1.5rem 0; }
.entry-content ul, .entry-content ol { padding-left: 1.5rem; margin-bottom: 1.5rem; }
.entry-content li { color: var(--muted-l); margin-bottom: .5rem; }
.entry-content ul li::marker { color: var(--copper); }

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer {
  background: #f8f9fb; border-top: 1px solid var(--border-d);
  margin-top: clamp(60px,8vw,100px);
}
.footer-top {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px;
  padding: clamp(48px,6vw,80px) var(--pad) clamp(40px,5vw,60px);
  max-width: var(--max); margin: 0 auto;
}
.footer-brand-desc { font-size: 12px; color: #5a5a6a; line-height: 1.85; margin-top: 16px; max-width: 280px; }
.footer-col-title { font-family: var(--sans); font-size: 10px; letter-spacing: .28em; text-transform: uppercase; color: var(--copper); margin-bottom: 18px; font-weight: 400; }
.footer-col a { display: block; font-size: 12px; color: #5a5a6a; margin-bottom: 10px; transition: color var(--fast); }
.footer-col a:hover { color: var(--copper); }
.footer-divider { border-top: 1px solid var(--border-d); }
.footer-bottom {
  max-width: var(--max); margin: 0 auto; padding: 20px var(--pad);
  display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap;
}
.footer-copy { font-size: 11px; color: var(--muted); letter-spacing: .05em; }
.footer-legal { display: flex; gap: 20px; }
.footer-legal a { font-size: 11px; color: var(--muted); transition: color var(--fast); }
.footer-legal a:hover { color: var(--copper); }

/* ============================================================
   UTILITY PAGES
   ============================================================ */
.page-content-wrap { max-width: 900px; margin: 0 auto; padding: clamp(60px,8vw,100px) var(--pad); }
.page-header { margin-bottom: 40px; padding-bottom: 32px; border-bottom: 1px solid var(--border-d); }

.usp-404 { min-height: 70vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 80px var(--pad); }
.usp-404-num { font-family: var(--serif); font-size: clamp(6rem,15vw,12rem); font-weight: 300; color: #e4e7ed; line-height: 1; margin-bottom: 16px; }

/* ============================================================
   FORMS
   ============================================================ */
.form-group { margin-bottom: 20px; }
.form-label { display: block; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; font-family: var(--sans); }
input[type="text"],input[type="email"],input[type="password"],input[type="number"],input[type="tel"],input[type="search"],input[type="url"],input[type="date"],textarea,select {
  width: 100%; padding: 12px 16px; background: #f2f4f7;
  border: 1px solid #dde2ea; border-radius: var(--r-sm);
  color: #0a0a14; font-family: var(--sans); font-size: 14px; font-weight: 300;
  outline: none; -webkit-appearance: none; transition: border-color var(--fast), box-shadow var(--fast);
}
input:focus, textarea:focus, select:focus { border-color: var(--copper); box-shadow: 0 0 0 3px rgba(192,123,58,.1); }
input::placeholder, textarea::placeholder { color: #b0b8c8; }
textarea { min-height: 120px; resize: vertical; }
select { cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c07b3a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }

/* ============================================================
   ANIMATIONS
   ============================================================ */
[data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
.delay-1 { transition-delay: .1s; }
.delay-2 { transition-delay: .2s; }
.delay-3 { transition-delay: .3s; }
.delay-4 { transition-delay: .4s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-compounds { display: grid; grid-template-columns: repeat(2,1fr); }
  .lot-inner { grid-template-columns: 1fr; gap: 40px; }
  .bulk-banner { grid-template-columns: 1fr; }
  .bulk-banner::before { display: none; }
  .bulk-ctas { flex-direction: row; }
  .serve-grid { grid-template-columns: repeat(2,1fr); }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .compounds-grid, ul.products.columns-3 { grid-template-columns: repeat(2,1fr) !important; }
  ul.products.columns-4 { grid-template-columns: repeat(2,1fr) !important; }
  .shop-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .feature-strip { grid-template-columns: repeat(2,1fr); }
  .feature-strip .fi:nth-child(2) { border-right: none; }
  .post-grid { grid-template-columns: repeat(2,1fr); }
  .single-product-layout { grid-template-columns: 1fr; }
  .product-gallery { position: static; }
}
@media (max-width: 768px) {
  #primary-nav { display: none; }
  .mob-toggle { display: flex; }
  .hero-compounds { grid-template-columns: 1fr; }
  .compounds-grid, ul.products.columns-3, ul.products.columns-4 { grid-template-columns: 1fr !important; }
  .serve-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .post-grid { grid-template-columns: 1fr; }
  .coa-grid { grid-template-columns: 1fr; }
  .lot-grid { grid-template-columns: repeat(3,1fr); }
  .hero-stats { gap: 20px; }
  .feature-strip { grid-template-columns: 1fr; }
  .fi { border-right: none; border-bottom: 1px solid var(--border-d); }
  .fi:last-child { border-bottom: none; }
}
@media (max-width: 480px) {
  .lot-grid { grid-template-columns: repeat(3,1fr); }
  .hero-ctas { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   PRINT
   ============================================================ */
@media print {
  #site-header, #site-footer, .sidebar, #ubar { display: none !important; }
  body { background: #fff; color: #000; }
}

/* ============================================================
   V6 LIGHT THEME — OVERRIDES & POLISH
   ============================================================ */

/* Ensure white backgrounds everywhere */
html, body { background: #f8f9fb !important; }

/* Section alternation for visual rhythm */
.section-alt { background: #ffffff; }
.section-white { background: #ffffff; }
.section-grey { background: #f2f4f7; }

/* Dark footer contrast anchor */
#site-footer { background: #0a0a14 !important; border-top: none !important; }
.footer-col-title { color: #c07b3a !important; }
.footer-col a { color: #5a5a6a !important; }
.footer-col a:hover { color: #c07b3a !important; }
.footer-brand-desc { color: #5a5a6a !important; }
.footer-copy { color: #3a3a4a !important; }
.footer-legal a { color: #3a3a4a !important; }
.footer-legal a:hover { color: #c07b3a !important; }
.logo-name.footer-logo { color: #f0e6d3 !important; }

/* Ticker stays dark */
.ticker-wrap { background: #0a0a14 !important; }

/* Eyebrow */
.eyebrow { color: #b86e2a !important; }

/* Cards get subtle shadow on white */
.cpd-card, .post-card, .serve-card {
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.cpd-card:hover, .post-card:hover, .serve-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,.1);
}
li.product { box-shadow: 0 2px 10px rgba(0,0,0,.05) !important; }

/* Forms */
input[type="text"],input[type="email"],input[type="password"],
input[type="number"],input[type="tel"],input[type="search"],
input[type="url"],input[type="date"],textarea,select {
  background: #fff !important;
  border: 1px solid #dde2ea !important;
  color: #0a0a14 !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
input:focus, textarea:focus, select:focus {
  border-color: #b86e2a !important;
  box-shadow: 0 0 0 3px rgba(184,110,42,.1) !important;
}

/* WooCommerce overrides */
.woocommerce-breadcrumb { color: #9098a8 !important; }
.woocommerce-breadcrumb a { color: #9098a8 !important; }
.woocommerce-result-count { color: #9098a8 !important; }
.woocommerce-message { background: #fff8f2 !important; border-color: rgba(184,110,42,.25) !important; color: #b86e2a !important; }
.woocommerce-error { background: #fff5f5 !important; }
.cart-totals, .order-totals { background: #f8f9fb !important; border-color: #e4e7ed !important; }
.woocommerce-tabs .tabs { border-bottom-color: #e4e7ed !important; }
.woocommerce-tabs .tabs li a { color: #9098a8 !important; }
.woocommerce-tabs .tabs li.active a { color: #b86e2a !important; border-bottom-color: #b86e2a !important; }
.shop_table th { color: #9098a8 !important; border-bottom-color: #e4e7ed !important; }
.shop_table td { color: #2a3040 !important; border-bottom-color: #f0f2f5 !important; }

/* WC product cards */
li.product { background: #fff !important; border-color: #e8eaee !important; }
.woocommerce-loop-product__title { color: #0a0a14 !important; }

/* Blog post list */
.post-card-title { color: #0a0a14 !important; }
.post-card-excerpt { color: #5a6478 !important; }
.post-card-meta { color: #9098a8 !important; }
.entry-content p { color: #3a4050 !important; }
.entry-content h2, .entry-content h3 { color: #0a0a14 !important; }
.entry-content blockquote { background: #f8f9fb !important; border-left-color: #b86e2a !important; color: #3a4050 !important; }
.entry-content code { background: rgba(184,110,42,.08) !important; border-color: rgba(184,110,42,.15) !important; color: #b86e2a !important; }
.entry-content pre { background: #f2f4f7 !important; border-color: #e4e7ed !important; }
.entry-content a { color: #b86e2a !important; border-bottom-color: rgba(184,110,42,.25) !important; }

/* Pagination */
.woocommerce-pagination a, .woocommerce-pagination span {
  background: #fff !important; border-color: #e4e7ed !important; color: #5a6478 !important;
}
.woocommerce-pagination .current { background: #b86e2a !important; border-color: #b86e2a !important; color: #fff !important; }

/* Sidebar widgets */
.widget { background: #fff !important; border-color: #e4e7ed !important; }
.widget-title { color: #b86e2a !important; border-bottom-color: #e4e7ed !important; }
.widget ul li { border-bottom-color: #f0f2f5 !important; }
.widget ul li a { color: #5a6478 !important; }
.widget ul li a:hover { color: #b86e2a !important; }
.widget ul li .count { background: #f2f4f7 !important; color: #9098a8 !important; }

/* COA panel light overrides */
.usp-coa-panel { background: #fff !important; border-color: rgba(184,110,42,.2) !important; }
.usp-coa-header { background: rgba(184,110,42,.04) !important; border-bottom-color: #eee !important; }
.usp-coa-title { color: #0a0a14 !important; }
.usp-coa-lbl { color: #9098a8 !important; }
.usp-coa-val { color: #2a3040 !important; }
.usp-coa-footer { background: #f8f9fb !important; color: #9098a8 !important; border-top-color: #eee !important; }

/* Stripe button section */
.usp-stripe-wrap { background: rgba(184,110,42,.05) !important; border-color: rgba(184,110,42,.22) !important; }
.usp-stripe-note { color: #9098a8 !important; }

/* 404 */
.usp-404-num { color: #e4e7ed !important; }

/* Reveal animations */
[data-reveal] { opacity: 0; transform: translateY(20px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }

/* Hero text on light bg */
.hero-pill { background: rgba(184,110,42,.08) !important; border-color: rgba(184,110,42,.2) !important; }
.hero-desc { color: #5a6478 !important; }
.stat-val { color: #0a0a14 !important; }
.stat-lbl { color: #9098a8 !important; }
.hc-card { background: #fff !important; border-color: #e4e7ed !important; }
.hc-name { color: var(--copper) !important; }
.hc-inci { color: #9098a8 !important; }

/* CTA in price block */
.usp-price-block { background: #f8f9fb !important; border-color: #e4e7ed !important; }
.usp-price-label { color: #b86e2a !important; }
.usp-price-note { color: #7a8090 !important; }

/* Trust badges */
.trust-badges { background: #f8f9fb !important; border-color: #e4e7ed !important; }
.trust-badge { color: #3a4050 !important; }

/* Feature strip */
.fi { background: #fff !important; border-right-color: #e8eaee !important; }
.fi-title { color: #0a0a14 !important; }
.fi-sub { color: #9098a8 !important; }
.fi-icon { background: rgba(184,110,42,.08) !important; border-color: rgba(184,110,42,.15) !important; }

/* Lot selector */
.lot-section { background: #f2f4f7 !important; }
.lot-btn { background: #fff !important; border-color: #e4e7ed !important; }
.lot-sz { color: #0a0a14 !important; }
.lot-btn.active .lot-sz { color: var(--copper) !important; }
.lot-notice { background: rgba(184,110,42,.06) !important; border-color: rgba(184,110,42,.18) !important; }

/* Bulk banner */
.bulk-section { background: #fff !important; }
.bulk-banner { background: linear-gradient(135deg,rgba(184,110,42,.06),rgba(201,168,76,.03)) !important; border-color: rgba(184,110,42,.18) !important; }
.bulk-title { color: #0a0a14 !important; }
.bulk-desc { color: #5a6478 !important; }
.bspec { color: #3a4050 !important; }

/* COA section on homepage */
.coa-panel { background: #fff !important; }
.coa-title { color: #0a0a14 !important; }
.coa-lbl { color: #9098a8 !important; }
.coa-val { color: #2a3040 !important; }
.coa-footer { background: #f8f9fb !important; color: #9098a8 !important; }

/* Serve section */
.serve-card { background: #fff !important; border-color: #e8eaee !important; }
.serve-title { color: #0a0a14 !important; }
.serve-desc { color: #5a6478 !important; }
.serve-ico { background: rgba(184,110,42,.08) !important; border-color: rgba(184,110,42,.15) !important; }

/* Shop page */
.shop-main { background: transparent !important; }
.cpd-name { color: #0a0a14 !important; }
.cpd-desc { color: #5a6478 !important; }
.cpd-img { background: linear-gradient(135deg,#f2f4f7,#eaecf0) !important; }
