/*
Theme Name: Discounted Stamps
Theme URI: https://discountedstamps.org
Author: Joseph Codsi
Description: Premium WooCommerce theme for selling USPS Forever Stamps. PC: 4 products/row. Mobile: 2 products/row.
Version: 5.0.0
License: GNU General Public License v2 or later
Text Domain: discounted-stamps
WC requires at least: 7.0
WC tested up to: 9.0
*/

/* ============================================================
   CSS VARIABLES
   ============================================================ */
:root {
  --primary:       #002868;
  --primary-dark:  #001a4a;
  --primary-light: #1a4a9e;
  --accent:        #BF0A30;
  --accent-dark:   #8B0722;
  --accent-light:  #e01040;
  --white:         #ffffff;
  --off-white:     #f8f9fc;
  --light-gray:    #f0f2f7;
  --mid-gray:      #e2e6ef;
  --text-dark:     #0d1b2e;
  --text-mid:      #3a4a5c;
  --text-light:    #6b7a90;
  --gold:          #c8922a;
  --gold-light:    #f0b429;
  --success:       #10b981;
  --font-heading:  'Playfair Display', Georgia, serif;
  --font-body:     'Source Sans 3', 'Helvetica Neue', sans-serif;
  --font-accent:   'Oswald', Impact, sans-serif;
  --shadow-sm:  0 2px 8px rgba(0,40,104,0.08);
  --shadow-md:  0 4px 20px rgba(0,40,104,0.12);
  --shadow-lg:  0 8px 40px rgba(0,40,104,0.18);
  --shadow-xl:  0 16px 60px rgba(0,40,104,0.22);
  --radius-sm:  6px;
  --radius-md:  12px;
  --radius-lg:  20px;
  --radius-xl:  32px;
  --transition: all 0.28s cubic-bezier(0.4,0,0.2,1);
  --max-width:  1280px;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  font-size: 16px;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
body {
  font-family: var(--font-body);
  color: var(--text-dark);
  background: var(--white);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  width: 100%;
  max-width: 100vw;
}
* { max-width: 100%; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: var(--transition); }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; max-width: 100%; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6 { font-family:var(--font-heading); font-weight:700; line-height:1.2; color:var(--text-dark); }
h1 { font-size: clamp(1.9rem,4vw,3.5rem); }
h2 { font-size: clamp(1.5rem,3vw,2.6rem); }
h3 { font-size: clamp(1.1rem,2vw,1.7rem); }
p  { color: var(--text-mid); font-size: 1rem; }

.section-label {
  font-family: var(--font-accent);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 500;
  margin-bottom: 0.5rem;
  display: block;
}

/* ============================================================
   LAYOUT
   ============================================================ */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
  box-sizing: border-box;
}
.section    { padding: 80px 0; }
.section-sm { padding: 50px 0; }
.text-center { text-align: center; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 30px;
  border-radius: 50px;
  font-family: var(--font-accent);
  font-size: 0.88rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
  transition: var(--transition);
  cursor: pointer;
  border: 2px solid transparent;
  white-space: nowrap;
}
.btn-primary { background:var(--accent); color:var(--white); border-color:var(--accent); box-shadow:0 4px 14px rgba(191,10,48,0.28); }
.btn-primary:hover { background:var(--accent-dark); border-color:var(--accent-dark); transform:translateY(-2px); }
.btn-secondary { background:transparent; color:var(--primary); border-color:var(--primary); }
.btn-secondary:hover { background:var(--primary); color:var(--white); transform:translateY(-2px); }
.btn-white { background:var(--white); color:var(--primary); border-color:var(--white); }
.btn-white:hover { background:transparent; color:var(--white); }
.btn-lg  { padding: 16px 40px; font-size: 0.95rem; }
.btn-sm  { padding: 10px 20px; font-size: 0.78rem; }

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announcement-bar {
  background: var(--accent);
  color: var(--white);
  text-align: center;
  padding: 10px 16px;
  font-family: var(--font-accent);
  font-size: 0.82rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
.announcement-bar a { color: var(--gold-light); text-decoration: underline; }

/* ============================================================
   TOP BAR
   ============================================================ */
.top-bar {
  background: var(--primary-dark);
  color: rgba(255,255,255,0.8);
  padding: 7px 0;
  font-size: 0.78rem;
  font-family: var(--font-accent);
  letter-spacing: 0.05em;
}
.top-bar .container { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.top-bar-left  { display:flex; align-items:center; gap:18px; }
.top-bar-right { display:flex; align-items:center; gap:14px; }
.top-bar a { color: rgba(255,255,255,0.8); }
.top-bar a:hover { color: var(--gold-light); }
.top-bar-item { display:flex; align-items:center; gap:5px; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  background: var(--white);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
}
.site-header.scrolled { box-shadow: var(--shadow-md); }
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  gap: 20px;
}

/* Logo */
.site-logo { display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0; }
.logo-icon  { width:44px; height:44px; background:var(--primary); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; font-size:1.3rem; flex-shrink:0; }
.logo-text  { line-height:1.2; }
.logo-text .brand-name    { font-family:var(--font-heading); font-size:1.2rem; font-weight:700; color:var(--primary); display:block; }
.logo-text .brand-tagline { font-family:var(--font-accent); font-size:0.6rem; letter-spacing:0.15em; color:var(--accent); text-transform:uppercase; display:block; }

/* Nav */
.main-nav { display:flex; align-items:center; gap:2px; }
.nav-item  { position:relative; }
.nav-link  {
  display:flex; align-items:center; gap:4px;
  padding: 8px 13px;
  font-family: var(--font-accent);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-dark);
  border-radius: var(--radius-sm);
  transition: var(--transition);
}
.nav-link:hover, .nav-link.active { color:var(--primary); background:var(--light-gray); }
.nav-link .chevron { font-size:0.6rem; transition:var(--transition); }
.nav-item:hover .chevron { transform:rotate(180deg); }

.dropdown {
  position:absolute; top:calc(100% + 6px); left:0;
  background:var(--white); border:1px solid var(--mid-gray);
  border-radius:var(--radius-md); box-shadow:var(--shadow-lg);
  min-width:195px; padding:6px;
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:var(--transition); z-index:1001;
}
.nav-item:hover .dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a { display:flex; align-items:center; gap:7px; padding:9px 12px; font-size:0.84rem; color:var(--text-mid); border-radius:var(--radius-sm); transition:var(--transition); }
.dropdown a:hover { background:var(--light-gray); color:var(--primary); }

/* Header actions */
.header-actions { display:flex; align-items:center; gap:10px; }
.header-icon-btn {
  width:38px; height:38px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; background:var(--light-gray); color:var(--text-dark);
  font-size:0.95rem; transition:var(--transition); position:relative; border:none; cursor:pointer;
}
.header-icon-btn:hover { background:var(--primary); color:var(--white); }
.cart-count {
  position:absolute; top:-4px; right:-4px;
  background:var(--accent); color:var(--white);
  font-size:0.6rem; font-weight:700;
  width:17px; height:17px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-accent);
}

/* Mobile menu button */
.mobile-menu-btn { display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer; }
.mobile-menu-btn span { display:block; width:22px; height:2px; background:var(--text-dark); border-radius:2px; transition:var(--transition); }

/* Search bar */
.search-bar { width:100%; background:var(--off-white); padding:12px 0; border-top:1px solid var(--mid-gray); }

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mobile-menu {
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:var(--text-dark); z-index:9997;
  transform:translateX(-100%); transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
  overflow-y:auto; padding:20px;
}
.mobile-menu.open { transform:translateX(0); }
.mobile-menu-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:28px; }
.mobile-menu-close  { color:var(--white); font-size:1.4rem; cursor:pointer; background:none; border:none; }
.mobile-nav-links   { display:flex; flex-direction:column; gap:3px; }
.mobile-nav-link    { display:block; padding:13px 14px; color:rgba(255,255,255,0.85); font-family:var(--font-accent); font-size:0.95rem; letter-spacing:0.06em; border-radius:var(--radius-md); transition:var(--transition); }
.mobile-nav-link:hover { background:rgba(255,255,255,0.08); color:white; }
.mobile-nav-divider { height:1px; background:rgba(255,255,255,0.1); margin:10px 0; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 55%, #1a5cb8 100%);
  position:relative; overflow:hidden;
  padding: 90px 0 70px;
  min-height: 85vh;
  display:flex; align-items:center;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Ccircle cx='30' cy='30' r='1.5' fill='rgba(255,255,255,0.07)'/%3E%3C/svg%3E");
  pointer-events:none;
}
.hero .container { display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; position:relative; z-index:1; }
.hero-content { color:var(--white); }
.hero-badge {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(200,146,42,0.2); border:1px solid rgba(200,146,42,0.4);
  color:var(--gold-light); padding:6px 16px; border-radius:50px;
  font-family:var(--font-accent); font-size:0.72rem; letter-spacing:0.14em;
  text-transform:uppercase; margin-bottom:20px;
}
.hero h1 { color:var(--white); margin-bottom:18px; line-height:1.1; }
.hero h1 em { font-style:normal; color:var(--gold-light); }
.hero-sub { color:rgba(255,255,255,0.82); font-size:1.05rem; margin-bottom:30px; line-height:1.72; max-width:470px; }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:36px; }
.hero-stats {
  display:flex; gap:28px;
  padding-top:28px; border-top:1px solid rgba(255,255,255,0.15);
}
.hero-stat .number { font-family:var(--font-accent); font-size:1.7rem; font-weight:700; color:var(--gold-light); display:block; line-height:1; }
.hero-stat .label  { color:rgba(255,255,255,0.6); font-size:0.72rem; text-transform:uppercase; letter-spacing:0.08em; font-family:var(--font-accent); }

.hero-visual { display:flex; flex-direction:column; gap:14px; position:relative; }
.hero-product-card {
  background:rgba(255,255,255,0.1); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.2); border-radius:var(--radius-lg);
  padding:24px; color:var(--white); transition:var(--transition);
}
.hero-product-card:hover { transform:translateY(-4px); background:rgba(255,255,255,0.15); }
.hero-card-top  { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.stamp-emoji    { font-size:3rem; line-height:1; }
.hero-card-badge { background:var(--accent); color:white; font-family:var(--font-accent); font-size:0.7rem; padding:3px 10px; border-radius:50px; }
.hero-card-title { font-family:var(--font-heading); font-size:1.05rem; margin-bottom:10px; }
.hero-card-price { display:flex; align-items:baseline; gap:8px; flex-wrap:wrap; }
.hero-price-current  { font-family:var(--font-accent); font-size:1.6rem; color:var(--gold-light); }
.hero-price-original { font-size:0.9rem; color:rgba(255,255,255,0.45); text-decoration:line-through; }
.hero-price-save     { font-family:var(--font-accent); font-size:0.7rem; color:var(--success); background:rgba(16,185,129,0.15); padding:2px 7px; border-radius:50px; }
.hero-card-btn {
  display:block; width:100%; margin-top:14px; text-align:center;
  padding:11px; background:var(--accent); color:white;
  border-radius:50px; font-family:var(--font-accent); font-size:0.8rem;
  letter-spacing:0.07em; transition:var(--transition);
}
.hero-card-btn:hover { background:var(--accent-dark); }
.hero-trust-strip { display:flex; gap:10px; flex-wrap:wrap; }
.hero-trust-item {
  background:rgba(255,255,255,0.1); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.15); border-radius:var(--radius-md);
  padding:10px 14px; display:flex; align-items:center; gap:7px;
  color:rgba(255,255,255,0.9); font-size:0.78rem; font-family:var(--font-accent);
  flex:1; min-width:100px;
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-strip { background:var(--primary); padding:18px 0; }
.trust-strip .container { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:9px; color:var(--white); }
.trust-item .icon-circle { width:38px; height:38px; background:rgba(255,255,255,0.15); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.trust-item .trust-title { font-family:var(--font-accent); font-size:0.8rem; letter-spacing:0.05em; color:var(--white); display:block; }
.trust-item .trust-sub   { font-size:0.68rem; color:rgba(255,255,255,0.6); display:block; }

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.section-heading { margin-bottom:44px; }
.section-heading.center { text-align:center; }
.section-heading h2 { margin-bottom:10px; }
.section-heading p  { max-width:580px; font-size:1rem; }
.section-heading.center p { margin:0 auto; }
.heading-underline { width:56px; height:4px; background:linear-gradient(90deg,var(--accent),var(--gold)); border-radius:2px; margin:14px 0 0; }
.section-heading.center .heading-underline { margin:14px auto 0; }

/* ============================================================
   PRODUCT GRID — 4 col PC, 2 col Mobile
   ============================================================ */
.shop-products-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  width: 100%;
}

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.product-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--mid-gray);
  transition: var(--transition);
  position: relative;
  display: flex;
  flex-direction: column;
}
.product-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-5px); border-color:transparent; }

.product-badge    { position:absolute; top:12px; left:12px; z-index:2; display:flex; gap:5px; }
.badge            { padding:3px 9px; border-radius:50px; font-family:var(--font-accent); font-size:0.65rem; letter-spacing:0.06em; }
.badge-sale       { background:var(--accent); color:white; }
.badge-new        { background:var(--success); color:white; }
.badge-popular    { background:var(--gold); color:white; }
.badge-bulk       { background:var(--primary); color:white; }

.product-wishlist {
  position:absolute; top:12px; right:12px; z-index:2;
  width:32px; height:32px; background:white; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-sm); transition:var(--transition); opacity:0; border:none; cursor:pointer;
}
.product-card:hover .product-wishlist { opacity:1; }
.product-wishlist:hover { background:var(--accent); color:white; }

.product-image {
  height: 200px;
  background: linear-gradient(135deg, var(--off-white), var(--light-gray));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; position: relative;
}
.product-image img { width:100%; height:100%; object-fit:cover; transition:var(--transition); }
.product-card:hover .product-image img { transform:scale(1.04); }
.product-quick-view {
  position:absolute; bottom:-38px; left:0; right:0;
  background:rgba(0,40,104,0.82); backdrop-filter:blur(4px);
  color:white; text-align:center; padding:9px;
  font-family:var(--font-accent); font-size:0.76rem;
  letter-spacing:0.07em; transition:var(--transition);
}
.product-card:hover .product-quick-view { bottom:0; }

.product-body     { padding:18px; display:flex; flex-direction:column; flex:1; }
.product-category { font-family:var(--font-accent); font-size:0.68rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); margin-bottom:5px; display:block; }
.product-name     { font-family:var(--font-heading); font-size:1rem; font-weight:600; color:var(--text-dark); margin-bottom:7px; line-height:1.3; flex:1; }
.product-rating   { display:flex; align-items:center; gap:5px; margin-bottom:10px; }
.stars            { color:var(--gold); font-size:0.85rem; }
.review-count     { font-size:0.75rem; color:var(--text-light); }
.product-price    { display:flex; align-items:baseline; gap:7px; flex-wrap:wrap; margin-bottom:14px; }
.price-current    { font-family:var(--font-accent); font-size:1.35rem; color:var(--primary); font-weight:600; }
.price-original   { font-size:0.88rem; color:var(--text-light); text-decoration:line-through; }
.price-save       { font-family:var(--font-accent); font-size:0.68rem; color:var(--success); background:rgba(16,185,129,0.1); padding:2px 7px; border-radius:50px; }

.product-footer   { }
.btn-cart {
  display:block; width:100%;
  padding:10px 16px; background:var(--primary); color:white;
  border-radius:50px; font-family:var(--font-accent); font-size:0.78rem;
  letter-spacing:0.06em; text-align:center; transition:var(--transition); border:2px solid var(--primary);
}
.btn-cart:hover { background:var(--primary-dark); border-color:var(--primary-dark); }

/* ============================================================
   FEATURES / WHY CHOOSE
   ============================================================ */
.why-choose { background:var(--white); position:relative; overflow:hidden; }
.why-choose::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--primary),var(--accent),var(--gold)); }
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.feature-card {
  padding:32px 26px; border-radius:var(--radius-lg);
  background:var(--off-white); border:1px solid var(--mid-gray);
  transition:var(--transition); position:relative; overflow:hidden;
}
.feature-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--primary),var(--accent)); transform:scaleX(0); transition:var(--transition); }
.feature-card:hover  { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.feature-card:hover::after { transform:scaleX(1); }
.feature-icon  { width:58px; height:58px; background:linear-gradient(135deg,var(--primary),var(--primary-light)); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin-bottom:18px; box-shadow:0 6px 20px rgba(0,40,104,0.2); }
.feature-title { font-family:var(--font-heading); font-size:1.08rem; margin-bottom:9px; }
.feature-desc  { font-size:0.9rem; color:var(--text-mid); line-height:1.65; }

/* ============================================================
   PROMO BANNER
   ============================================================ */
.promo-banner { background:linear-gradient(135deg,var(--primary-dark),var(--accent-dark)); padding:55px 0; position:relative; overflow:hidden; }
.promo-banner .container { display:flex; align-items:center; justify-content:space-between; gap:36px; flex-wrap:wrap; }
.promo-content { color:white; }
.promo-content h2 { color:white; margin-bottom:8px; }
.promo-content p  { color:rgba(255,255,255,0.8); max-width:480px; }
.promo-actions    { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card {
  background:white; border-radius:var(--radius-lg); padding:28px;
  border:1px solid var(--mid-gray); transition:var(--transition); position:relative;
}
.testimonial-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); }
.testimonial-card::before { content:'"'; position:absolute; top:16px; right:20px; font-family:var(--font-heading); font-size:4.5rem; color:var(--mid-gray); line-height:1; }
.testimonial-stars  { color:var(--gold); margin-bottom:12px; font-size:1rem; }
.testimonial-text   { font-size:0.9rem; color:var(--text-mid); line-height:1.75; margin-bottom:20px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:10px; }
.author-avatar      { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--primary-light)); display:flex; align-items:center; justify-content:center; font-family:var(--font-accent); font-size:1rem; color:white; font-weight:600; flex-shrink:0; }
.author-name        { font-family:var(--font-heading); font-size:0.9rem; font-weight:600; display:block; }
.author-location    { font-size:0.74rem; color:var(--text-light); display:flex; align-items:center; gap:3px; }
.verified-badge     { display:inline-flex; align-items:center; gap:3px; font-family:var(--font-accent); font-size:0.64rem; color:var(--success); background:rgba(16,185,129,0.1); padding:2px 7px; border-radius:50px; margin-top:3px; letter-spacing:0.04em; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; max-width:980px; margin:0 auto; }
.faq-item { border:1px solid var(--mid-gray); border-radius:var(--radius-md); overflow:hidden; transition:var(--transition); }
.faq-item.open { border-color:var(--primary); box-shadow:var(--shadow-sm); }
.faq-question { display:flex; align-items:center; justify-content:space-between; padding:18px 22px; cursor:pointer; font-family:var(--font-heading); font-size:0.92rem; font-weight:600; color:var(--text-dark); gap:10px; background:white; transition:var(--transition); }
.faq-question:hover { background:var(--off-white); }
.faq-item.open .faq-question { background:var(--primary); color:white; }
.faq-icon { width:26px; height:26px; background:var(--light-gray); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1rem; font-weight:700; flex-shrink:0; transition:var(--transition); }
.faq-item.open .faq-icon { background:rgba(255,255,255,0.2); color:white; }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.32s ease; }
.faq-item.open .faq-answer { max-height:280px; }
.faq-answer-inner { padding:18px 22px; font-size:0.9rem; color:var(--text-mid); line-height:1.7; }

/* ============================================================
   BULK SECTION
   ============================================================ */
.bulk-section { background:var(--white); padding:80px 0; }
.bulk-inner {
  background:linear-gradient(135deg,var(--primary-dark),var(--primary));
  border-radius:var(--radius-xl); padding:56px 52px;
  display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center;
  position:relative; overflow:hidden;
}
.bulk-content { color:white; position:relative; z-index:1; }
.bulk-content h2 { color:white; margin-bottom:14px; }
.bulk-content p  { color:rgba(255,255,255,0.8); margin-bottom:24px; }
.bulk-features   { display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.bulk-feature-item { display:flex; align-items:center; gap:9px; color:rgba(255,255,255,0.9); font-size:0.9rem; }
.bulk-feature-item .check { color:var(--success); }
.bulk-tiers      { position:relative; z-index:1; display:flex; flex-direction:column; gap:12px; }
.bulk-tier { background:rgba(255,255,255,0.1); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,0.2); border-radius:var(--radius-md); padding:18px 22px; display:flex; align-items:center; justify-content:space-between; color:white; transition:var(--transition); }
.bulk-tier:hover { background:rgba(255,255,255,0.17); }
.bulk-tier.featured { border-color:var(--gold-light); background:rgba(200,146,42,0.18); }
.tier-qty   { font-family:var(--font-accent); font-size:0.85rem; }
.tier-price { font-family:var(--font-accent); font-size:1.25rem; color:var(--gold-light); }
.tier-save  { font-size:0.72rem; color:var(--success); background:rgba(16,185,129,0.18); padding:2px 8px; border-radius:50px; font-family:var(--font-accent); }

/* ============================================================
   SHIPPING SECTION
   ============================================================ */
.shipping-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.shipping-card { background:white; border-radius:var(--radius-lg); padding:26px 22px; text-align:center; border:1px solid var(--mid-gray); transition:var(--transition); }
.shipping-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); }
.shipping-icon  { font-size:2.2rem; margin-bottom:12px; display:block; }
.shipping-title { font-family:var(--font-heading); font-size:0.95rem; margin-bottom:6px; }
.shipping-desc  { font-size:0.82rem; color:var(--text-light); line-height:1.6; }

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter-section { background:linear-gradient(135deg,var(--primary),var(--primary-light)); padding:75px 0; position:relative; overflow:hidden; }
.newsletter-inner   { max-width:580px; margin:0 auto; text-align:center; color:white; position:relative; }
.newsletter-inner h2 { color:white; margin-bottom:10px; }
.newsletter-inner p  { color:rgba(255,255,255,0.8); margin-bottom:28px; }
.newsletter-form     { display:flex; gap:10px; flex-wrap:wrap; }
.newsletter-input    { flex:1; min-width:220px; padding:15px 22px; border-radius:50px; border:2px solid rgba(255,255,255,0.3); background:rgba(255,255,255,0.1); color:white; font-size:0.92rem; font-family:var(--font-body); outline:none; transition:var(--transition); }
.newsletter-input::placeholder { color:rgba(255,255,255,0.6); }
.newsletter-input:focus { border-color:rgba(255,255,255,0.65); background:rgba(255,255,255,0.15); }
.newsletter-privacy { font-size:0.75rem; color:rgba(255,255,255,0.5); margin-top:10px; }

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.blog-card { background:white; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--mid-gray); transition:var(--transition); }
.blog-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.blog-image { height:190px; background:linear-gradient(135deg,var(--primary),var(--primary-light)); display:flex; align-items:center; justify-content:center; font-size:3.2rem; position:relative; overflow:hidden; }
.blog-image img { width:100%; height:100%; object-fit:cover; }
.blog-category { position:absolute; bottom:10px; left:10px; background:var(--accent); color:white; font-family:var(--font-accent); font-size:0.66rem; padding:3px 9px; border-radius:50px; }
.blog-body { padding:22px; }
.blog-meta  { display:flex; gap:10px; margin-bottom:8px; font-size:0.75rem; color:var(--text-light); font-family:var(--font-accent); }
.blog-title { font-family:var(--font-heading); font-size:1rem; color:var(--text-dark); margin-bottom:8px; line-height:1.35; transition:var(--transition); }
.blog-card:hover .blog-title { color:var(--primary); }
.blog-excerpt   { font-size:0.85rem; color:var(--text-mid); line-height:1.65; margin-bottom:14px; }
.blog-read-more { color:var(--accent); font-family:var(--font-accent); font-size:0.78rem; display:flex; align-items:center; gap:5px; transition:var(--transition); }
.blog-read-more:hover { gap:9px; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-hero { background:linear-gradient(135deg,var(--primary-dark),var(--primary)); padding:65px 0; text-align:center; color:white; }
.about-hero h1 { color:white; margin-bottom:12px; }
.about-hero p  { color:rgba(255,255,255,0.8); max-width:580px; margin:0 auto; }
.about-breadcrumb { display:flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-accent); font-size:0.76rem; color:rgba(255,255,255,0.55); margin-top:14px; flex-wrap:wrap; }
.about-breadcrumb a { color:var(--gold-light); }
.mission-grid { display:grid; grid-template-columns:1fr 1fr; gap:55px; align-items:center; }
.mission-image { border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-xl); min-height:380px; background:linear-gradient(135deg,var(--light-gray),var(--mid-gray)); display:flex; align-items:center; justify-content:center; font-size:7rem; }
.stats-strip  { background:var(--primary); padding:46px 0; }
.stats-inner  { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; text-align:center; }
.stat-item .stat-number { font-family:var(--font-accent); font-size:2.2rem; color:var(--gold-light); display:block; }
.stat-item .stat-label  { color:rgba(255,255,255,0.65); font-size:0.8rem; font-family:var(--font-accent); letter-spacing:0.1em; }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.team-card  { text-align:center; }
.team-avatar{ width:90px; height:90px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--primary-light)); margin:0 auto 12px; display:flex; align-items:center; justify-content:center; font-size:2rem; box-shadow:var(--shadow-md); }
.team-name  { font-family:var(--font-heading); font-weight:600; margin-bottom:3px; font-size:0.95rem; }
.team-role  { font-size:0.78rem; color:var(--accent); font-family:var(--font-accent); letter-spacing:0.07em; }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:50px; align-items:start; }
.contact-info-card { background:white; border-radius:var(--radius-lg); padding:32px; border:1px solid var(--mid-gray); }
.contact-info-item { display:flex; gap:14px; margin-bottom:24px; }
.contact-icon  { width:44px; height:44px; background:linear-gradient(135deg,var(--primary),var(--primary-light)); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; color:white; font-size:1.05rem; flex-shrink:0; }
.contact-detail .label { font-family:var(--font-accent); font-size:0.7rem; letter-spacing:0.1em; color:var(--accent); text-transform:uppercase; display:block; margin-bottom:3px; }
.contact-detail .value { font-weight:600; color:var(--text-dark); font-size:0.9rem; }
.contact-form-card { background:white; border-radius:var(--radius-lg); padding:36px; border:1px solid var(--mid-gray); box-shadow:var(--shadow-sm); }
.form-row     { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.form-group   { margin-bottom:18px; }
.form-label   { display:block; font-family:var(--font-accent); font-size:0.73rem; letter-spacing:0.1em; color:var(--text-mid); text-transform:uppercase; margin-bottom:7px; }
.form-input, .form-textarea, .form-select { width:100%; padding:13px 17px; border:1.5px solid var(--mid-gray); border-radius:var(--radius-md); font-family:var(--font-body); font-size:0.92rem; color:var(--text-dark); background:var(--off-white); transition:var(--transition); outline:none; }
.form-input:focus, .form-textarea:focus { border-color:var(--primary); background:white; box-shadow:0 0 0 3px rgba(0,40,104,0.07); }
.form-textarea { resize:vertical; min-height:120px; }

/* ============================================================
   TRACK ORDER
   ============================================================ */
.track-form-section { background:var(--off-white); padding:80px 0; }
.track-form-box { max-width:580px; margin:0 auto; background:white; border-radius:var(--radius-xl); padding:44px; box-shadow:var(--shadow-lg); border:1px solid var(--mid-gray); }
.track-steps  { display:flex; gap:0; margin-top:36px; }
.track-step   { flex:1; text-align:center; position:relative; }
.track-step:not(:last-child)::after { content:''; position:absolute; top:17px; left:50%; right:-50%; height:2px; background:var(--mid-gray); z-index:0; }
.track-step.done:not(:last-child)::after { background:var(--success); }
.step-dot     { width:34px; height:34px; border-radius:50%; background:var(--mid-gray); border:3px solid white; display:flex; align-items:center; justify-content:center; margin:0 auto 7px; font-size:0.85rem; position:relative; z-index:1; }
.track-step.done .step-dot   { background:var(--success); color:white; }
.track-step.active .step-dot { background:var(--primary); color:white; }
.step-label   { font-family:var(--font-accent); font-size:0.65rem; letter-spacing:0.07em; color:var(--text-light); }

/* ============================================================
   POLICY PAGES
   ============================================================ */
.policy-content { background:white; border-radius:var(--radius-lg); padding:44px; border:1px solid var(--mid-gray); }
.policy-content h2 { margin:28px 0 10px; font-size:1.25rem; }
.policy-content h3 { margin:20px 0 8px; font-size:1.05rem; color:var(--primary); }
.policy-content p  { margin-bottom:12px; font-size:0.93rem; }
.policy-content ul { margin:10px 0 14px 18px; }
.policy-content ul li { margin-bottom:7px; font-size:0.93rem; color:var(--text-mid); list-style:disc; }

/* ============================================================
   SHOP SIDEBAR & LAYOUT
   ============================================================ */
.shop-layout  { display:grid; grid-template-columns:240px 1fr; gap:32px; align-items:start; }
.shop-sidebar { background:white; border-radius:var(--radius-lg); padding:24px; border:1px solid var(--mid-gray); position:sticky; top:88px; }
.sidebar-section { margin-bottom:24px; }
.sidebar-title   { font-family:var(--font-accent); font-size:0.75rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-dark); margin-bottom:12px; padding-bottom:8px; border-bottom:2px solid var(--mid-gray); }
.filter-option   { display:flex; align-items:center; justify-content:space-between; padding:7px 0; cursor:pointer; }
.filter-option label { display:flex; align-items:center; gap:8px; cursor:pointer; font-size:0.88rem; color:var(--text-mid); }
.filter-count    { background:var(--light-gray); padding:1px 7px; border-radius:50px; font-size:0.68rem; color:var(--text-light); font-family:var(--font-accent); }
.shop-toolbar    { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; flex-wrap:wrap; gap:10px; }
.sort-select     { padding:9px 14px; border:1.5px solid var(--mid-gray); border-radius:var(--radius-md); font-family:var(--font-body); font-size:0.88rem; color:var(--text-dark); background:white; outline:none; cursor:pointer; }

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
.product-page-grid { display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:start; }
.product-gallery   { position:sticky; top:88px; }
.gallery-main      { border-radius:var(--radius-xl); overflow:hidden; background:var(--light-gray); height:430px; display:flex; align-items:center; justify-content:center; font-size:7rem; margin-bottom:10px; position:relative; }
.gallery-main img  { width:100%; height:100%; object-fit:contain; }
.gallery-thumbs    { display:flex; gap:9px; }
.gallery-thumb     { width:74px; height:74px; border-radius:var(--radius-md); overflow:hidden; background:var(--light-gray); border:2px solid transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:1.4rem; transition:var(--transition); }
.gallery-thumb.active, .gallery-thumb:hover { border-color:var(--primary); }
.product-info .product-title      { font-size:clamp(1.5rem,2.5vw,2rem); margin-bottom:10px; }
.product-info .product-price-large{ font-family:var(--font-accent); font-size:2rem; color:var(--primary); margin-bottom:5px; }
.product-info .original-price-large { font-size:1rem; color:var(--text-light); text-decoration:line-through; margin-right:7px; }
.product-info .save-tag           { background:var(--accent); color:white; font-family:var(--font-accent); font-size:0.75rem; padding:3px 10px; border-radius:50px; }
.stock-status  { display:flex; align-items:center; gap:5px; font-family:var(--font-accent); font-size:0.78rem; letter-spacing:0.07em; margin:14px 0; }
.stock-dot     { width:7px; height:7px; border-radius:50%; background:var(--success); }
.quantity-selector { display:flex; align-items:center; border:2px solid var(--mid-gray); border-radius:50px; overflow:hidden; width:fit-content; margin-bottom:20px; }
.qty-btn   { width:42px; height:42px; background:var(--light-gray); border:none; font-size:1.1rem; cursor:pointer; transition:var(--transition); font-weight:600; color:var(--text-dark); }
.qty-btn:hover { background:var(--primary); color:white; }
.qty-input { width:56px; text-align:center; border:none; font-family:var(--font-accent); font-size:0.95rem; font-weight:600; outline:none; padding:9px 0; }
.product-actions { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:24px; }
.product-actions .btn-cart-lg { flex:1; padding:15px 26px; background:var(--accent); color:white; border-radius:50px; font-family:var(--font-accent); font-size:0.9rem; letter-spacing:0.07em; transition:var(--transition); border:2px solid var(--accent); text-align:center; }
.product-actions .btn-cart-lg:hover { background:var(--accent-dark); }
.product-actions .btn-wishlist { width:52px; height:52px; border:2px solid var(--mid-gray); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.05rem; color:var(--text-mid); transition:var(--transition); }
.product-actions .btn-wishlist:hover { border-color:var(--accent); color:var(--accent); }
.product-meta-list  { font-size:0.85rem; color:var(--text-mid); display:flex; flex-direction:column; gap:7px; margin-bottom:20px; padding-top:18px; border-top:1px solid var(--mid-gray); }
.product-meta-list .meta-row { display:flex; gap:7px; }
.product-meta-list .meta-key { color:var(--text-dark); font-weight:600; min-width:95px; }
.secure-checkout { display:flex; align-items:center; gap:9px; padding:12px 18px; background:var(--light-gray); border-radius:var(--radius-md); font-size:0.82rem; color:var(--text-mid); }
.secure-checkout .lock-icon { color:var(--success); font-size:0.95rem; }

/* Sticky cart bar */
.sticky-cart-bar { position:fixed; bottom:0; left:0; right:0; background:white; border-top:1px solid var(--mid-gray); padding:12px 22px; z-index:990; display:flex; align-items:center; justify-content:space-between; gap:14px; box-shadow:0 -4px 18px rgba(0,0,0,0.09); transform:translateY(100%); transition:var(--transition); }
.sticky-cart-bar.show { transform:translateY(0); }
.sticky-product-name { font-family:var(--font-heading); font-size:0.95rem; font-weight:600; }
.sticky-price { font-family:var(--font-accent); font-size:1.15rem; color:var(--primary); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background:var(--text-dark); padding:75px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:44px; margin-bottom:55px; }
.footer-brand p { color:rgba(255,255,255,0.5); font-size:0.88rem; line-height:1.7; margin-bottom:20px; }
.footer-social   { display:flex; gap:9px; }
.social-btn { width:36px; height:36px; background:rgba(255,255,255,0.08); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.55); font-size:0.85rem; transition:var(--transition); border:1px solid rgba(255,255,255,0.1); }
.social-btn:hover { background:var(--accent); color:white; border-color:var(--accent); }
.footer-title    { font-family:var(--font-accent); font-size:0.8rem; letter-spacing:0.15em; text-transform:uppercase; color:white; margin-bottom:18px; }
.footer-links    { display:flex; flex-direction:column; gap:9px; }
.footer-links a  { color:rgba(255,255,255,0.5); font-size:0.88rem; transition:var(--transition); display:flex; align-items:center; gap:5px; }
.footer-links a:hover { color:var(--gold-light); padding-left:3px; }
.footer-contact-item { display:flex; gap:9px; margin-bottom:12px; color:rgba(255,255,255,0.5); font-size:0.85rem; }
.footer-contact-item .icon { color:var(--accent); font-size:0.85rem; margin-top:2px; flex-shrink:0; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding:22px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; }
.footer-bottom p { color:rgba(255,255,255,0.3); font-size:0.78rem; }
.footer-payment  { display:flex; gap:7px; align-items:center; flex-wrap:wrap; }
.payment-badge   { background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.11); border-radius:var(--radius-sm); padding:5px 10px; font-family:var(--font-accent); font-size:0.68rem; color:rgba(255,255,255,0.45); letter-spacing:0.07em; }

/* ============================================================
   LIVE CHAT & BACK TO TOP
   ============================================================ */
.live-chat-btn { position:fixed; bottom:26px; right:26px; z-index:999; background:linear-gradient(135deg,var(--primary),var(--primary-light)); color:white; width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.3rem; box-shadow:0 5px 20px rgba(0,40,104,0.32); transition:var(--transition); cursor:pointer; border:3px solid white; }
.live-chat-btn:hover { transform:scale(1.1) translateY(-2px); }
.live-chat-pulse { position:absolute; top:0; right:0; width:14px; height:14px; background:var(--success); border-radius:50%; border:2px solid white; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{transform:scale(1)}50%{transform:scale(1.3)} }
.back-to-top { position:fixed; bottom:96px; right:26px; width:42px; height:42px; background:var(--accent); color:white; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.95rem; cursor:pointer; box-shadow:var(--shadow-md); transition:var(--transition); opacity:0; visibility:hidden; z-index:998; border:none; }
.back-to-top.visible { opacity:1; visibility:visible; }
.back-to-top:hover { background:var(--accent-dark); transform:translateY(-2px); }

/* Toast */
.toast { position:fixed; top:22px; right:22px; background:var(--text-dark); color:white; padding:13px 18px; border-radius:var(--radius-md); font-size:0.85rem; display:flex; align-items:center; gap:9px; box-shadow:var(--shadow-xl); z-index:9999; transform:translateX(120%); transition:transform 0.4s cubic-bezier(0.4,0,0.2,1); }
.toast.show { transform:translateX(0); }
.toast .toast-icon { color:var(--success); font-size:1.05rem; }

/* Popup */
.popup-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.55); backdrop-filter:blur(3px); z-index:9998; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:var(--transition); }
.popup-overlay.active { opacity:1; visibility:visible; }
.popup-box { background:white; border-radius:var(--radius-xl); max-width:500px; width:92%; overflow:hidden; transform:translateY(18px); transition:var(--transition); position:relative; }
.popup-overlay.active .popup-box { transform:translateY(0); }
.popup-header { background:linear-gradient(135deg,var(--primary-dark),var(--primary)); padding:28px; text-align:center; color:white; }
.popup-header h3 { color:white; font-size:1.4rem; margin-bottom:7px; }
.popup-header p  { color:rgba(255,255,255,0.8); font-size:0.88rem; }
.popup-body  { padding:28px; }
.popup-close { position:absolute; top:14px; right:14px; width:30px; height:30px; background:rgba(255,255,255,0.18); border-radius:50%; display:flex; align-items:center; justify-content:center; color:white; font-size:1rem; cursor:pointer; transition:var(--transition); border:none; }
.popup-close:hover { background:rgba(255,255,255,0.28); }

/* Breadcrumb */
.breadcrumb { background:var(--off-white); border-bottom:1px solid var(--mid-gray); }
.breadcrumb-list { display:flex; align-items:center; gap:8px; padding:11px 0; font-family:var(--font-accent); font-size:0.75rem; letter-spacing:0.05em; color:var(--text-light); flex-wrap:wrap; }
.breadcrumb-list li { display:flex; align-items:center; gap:8px; }
.breadcrumb-list li:not(:last-child)::after { content:'›'; }
.breadcrumb-list a { color:var(--primary); }
.breadcrumb-list a:hover { color:var(--accent); }

/* Animations */
@keyframes fadeInUp { from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)} }
[data-animate] { opacity:0; }
[data-animate].animated { animation:fadeInUp 0.6s ease forwards; }

/* ============================================================
   WOOCOMMERCE OVERRIDES
   ============================================================ */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button { background:var(--primary); color:white; border-radius:50px; padding:11px 26px; font-family:var(--font-accent); font-size:0.84rem; letter-spacing:0.07em; text-transform:uppercase; border:2px solid var(--primary); transition:var(--transition); }
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt { background:var(--accent); border-color:var(--accent); }
.woocommerce span.onsale { background:var(--accent); border-radius:50px; font-family:var(--font-accent); font-size:0.68rem; }
.woocommerce .price { font-family:var(--font-accent); color:var(--primary); }
.woocommerce-product-rating .star-rating { color:var(--gold); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select { border:1.5px solid var(--mid-gray); border-radius:var(--radius-md); padding:11px 15px; font-family:var(--font-body); transition:var(--transition); }
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { border-color:var(--primary); outline:none; box-shadow:0 0 0 3px rgba(0,40,104,0.07); }
.woocommerce table.shop_table { width:100% !important; border-radius:var(--radius-lg); overflow:hidden; border-collapse:collapse; background:white; }
.woocommerce table.shop_table th { background:var(--primary); color:white; padding:13px 18px; font-family:var(--font-accent); font-size:0.75rem; letter-spacing:0.11em; text-transform:uppercase; }
.woocommerce table.shop_table td { padding:15px 18px; vertical-align:middle; border-bottom:1px solid var(--mid-gray); }
.woocommerce .cart_totals { background:white; border:1px solid var(--mid-gray); border-radius:var(--radius-lg); padding:26px; max-width:440px; margin-left:auto; box-shadow:var(--shadow-md); }
.woocommerce .wc-proceed-to-checkout a.checkout-button { display:block; text-align:center; width:100%; padding:15px; background:var(--accent); color:white; border-radius:50px; font-family:var(--font-accent); font-size:0.95rem; letter-spacing:0.07em; text-transform:uppercase; margin-top:14px; }
.woocommerce #payment #place_order { width:100%; display:block; padding:16px; font-size:1rem; letter-spacing:0.07em; background:var(--accent); border-radius:50px; font-family:var(--font-accent); cursor:pointer; border:none; color:white; margin-top:14px; }
.woocommerce ul.products { display:grid !important; grid-template-columns:repeat(4,1fr) !important; gap:22px !important; float:none !important; margin:0 !important; padding:0 !important; width:100% !important; }
.woocommerce ul.products li.product { width:100% !important; margin:0 !important; float:none !important; }
.woocommerce-account .woocommerce { display:grid; grid-template-columns:210px 1fr; gap:28px; padding:40px 24px; max-width:var(--max-width); margin:0 auto; align-items:start; }
.woocommerce-account .woocommerce-MyAccount-navigation { background:white; border-radius:var(--radius-lg); padding:10px; border:1px solid var(--mid-gray); position:sticky; top:88px; }
.woocommerce-account .woocommerce-MyAccount-navigation li { list-style:none; border-bottom:1px solid var(--mid-gray); }
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child { border-bottom:none; }
.woocommerce-account .woocommerce-MyAccount-navigation a { display:block; padding:11px 14px; font-family:var(--font-accent); font-size:0.82rem; letter-spacing:0.06em; color:var(--text-mid); border-radius:var(--radius-sm); transition:var(--transition); }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation a:hover { background:var(--primary); color:white; }
.woocommerce-account .woocommerce-MyAccount-content { background:white; border-radius:var(--radius-lg); padding:28px; border:1px solid var(--mid-gray); }
.woocommerce-breadcrumb { font-family:var(--font-accent); font-size:0.75rem; color:rgba(255,255,255,0.55); margin-bottom:7px; letter-spacing:0.05em; }
.woocommerce-breadcrumb a { color:var(--gold-light); }
.woocommerce-message,
.woocommerce-info { border-top-color:var(--primary); border-radius:var(--radius-md); margin-bottom:18px; }
.woocommerce-error { border-top-color:var(--accent); border-radius:var(--radius-md); }
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce { max-width:var(--max-width); margin:0 auto; padding:40px 24px; }
.woocommerce .cart-collaterals { width:100%; display:flex; justify-content:flex-end; margin-top:28px; }
.woocommerce .cart_totals h2 { font-family:var(--font-heading); font-size:1.2rem; margin-bottom:18px; padding-bottom:10px; border-bottom:2px solid var(--mid-gray); }
.woocommerce form.checkout { display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:start; }
.woocommerce-checkout #order_review { background:white; border:1px solid var(--mid-gray); border-radius:var(--radius-lg); padding:24px; }
.woocommerce #payment { background:var(--off-white); border-radius:var(--radius-lg); padding:22px; border:1px solid var(--mid-gray); }
.woocommerce .coupon { display:flex; gap:9px; flex-wrap:wrap; align-items:center; }
.woocommerce .coupon input#coupon_code { flex:1; min-width:160px; padding:11px 15px; border:1.5px solid var(--mid-gray); border-radius:50px; font-family:var(--font-body); }

/* ============================================================
   RESPONSIVE — Tablet & Mobile
   ============================================================ */

/* Tablet */
@media (max-width: 1099px) {
  .shop-products-grid { grid-template-columns:repeat(3,1fr) !important; }
  .woocommerce ul.products { grid-template-columns:repeat(3,1fr) !important; }
  .footer-grid { grid-template-columns:1.5fr 1fr 1fr; }
  .footer-grid > :nth-child(4) { grid-column:1/-1; }
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .hero .container { grid-template-columns:1fr; }
  .hero-visual { display:none; }
  .hero { min-height:auto; padding:70px 0 55px; }
}

/* Mobile */
@media (max-width: 768px) {
  /* Global */
  html,body { overflow-x:hidden !important; }
  .container { padding:0 14px !important; }
  .section { padding:44px 0 !important; }
  .section-heading { margin-bottom:26px; }
  .section-heading h2 { font-size:1.4rem; }

  /* Announcement */
  .announcement-bar { font-size:0.7rem; padding:8px 12px; }

  /* Top bar */
  .top-bar { display:none; }

  /* Header */
  .header-inner { padding:10px 0; gap:8px; }
  .logo-text .brand-tagline { display:none; }
  .main-nav { display:none; }
  .header-icon-btn:not(.cart-icon) { display:none; }
  .header-actions > .btn.btn-sm { display:none; }
  .mobile-menu-btn { display:flex; }

  /* Hero */
  .hero { padding:40px 0 34px; min-height:auto; }
  .hero .container { grid-template-columns:1fr; gap:0; }
  .hero-visual { display:none; }
  .hero h1 { font-size:1.75rem; line-height:1.18; }
  .hero-sub { font-size:0.9rem; margin-bottom:20px; }
  .hero-badge { font-size:0.65rem; padding:5px 12px; margin-bottom:14px; }
  .hero-cta { flex-direction:column; gap:9px; margin-bottom:22px; }
  .hero-cta .btn { width:100%; justify-content:center; }
  .hero-stats { display:grid; grid-template-columns:1fr 1fr; gap:12px; padding-top:18px; }
  .hero-stat .number { font-size:1.35rem; }
  .hero-stat .label  { font-size:0.62rem; }

  /* Trust strip */
  .trust-strip .container { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
  .trust-item .trust-sub { display:none; }
  .trust-item .icon-circle { width:28px; height:28px; font-size:0.75rem; }
  .trust-item .trust-title { font-size:0.68rem; }

  /* PRODUCT GRID — 2 columns on mobile */
  .shop-products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .product-image { height:145px; }
  .product-body  { padding:11px; }
  .product-name  { font-size:0.82rem; }
  .price-current { font-size:1.1rem; }
  .price-original { font-size:0.75rem; }
  .btn-cart { font-size:0.7rem; padding:8px 9px; }

  /* Features */
  .features-grid { grid-template-columns:1fr; gap:13px; }
  .feature-card  { padding:22px 17px; }

  /* Promo */
  .promo-banner .container { flex-direction:column; text-align:center; gap:18px; align-items:center; }
  .promo-content h2 { font-size:1.3rem; }
  .promo-actions { flex-direction:column; align-items:center; width:100%; }
  .promo-actions .btn { width:100%; max-width:270px; justify-content:center; }

  /* Testimonials */
  .testimonials-grid { grid-template-columns:1fr; gap:13px; }

  /* Blog */
  .blog-grid { grid-template-columns:1fr; gap:13px; }

  /* FAQ */
  .faq-grid { grid-template-columns:1fr; gap:8px; max-width:100%; }
  .faq-question { font-size:0.84rem; padding:13px 15px; }

  /* Bulk */
  .bulk-inner { grid-template-columns:1fr; padding:26px 18px; gap:22px; }

  /* Shipping */
  .shipping-grid { grid-template-columns:1fr 1fr; gap:10px; }

  /* Newsletter */
  .newsletter-form { flex-direction:column; gap:9px; }
  .newsletter-input { width:100%; min-width:unset; }
  .newsletter-form .btn { width:100%; justify-content:center; }

  /* Footer */
  .footer-grid { grid-template-columns:1fr; gap:26px; margin-bottom:26px; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .footer-payment { justify-content:center; flex-wrap:wrap; }

  /* About */
  .mission-grid { grid-template-columns:1fr; gap:22px; }
  .stats-inner  { grid-template-columns:1fr 1fr; }
  .team-grid    { grid-template-columns:1fr 1fr; }
  .about-hero h1 { font-size:1.7rem; }

  /* Contact */
  .contact-grid { grid-template-columns:1fr; gap:18px; }
  .contact-form-card { padding:22px 16px; }
  .form-row     { grid-template-columns:1fr; gap:0; }

  /* Track order */
  .track-form-box { padding:22px 16px; }

  /* Policy */
  .policy-content { padding:20px 16px; }

  /* Shop layout */
  .shop-layout { grid-template-columns:1fr; }
  .shop-sidebar { position:static; }

  /* Single product */
  .product-page-grid { grid-template-columns:1fr; gap:24px; }
  .product-gallery { position:static; }
  .gallery-main { height:270px; }

  /* WooCommerce mobile */
  .woocommerce-cart .woocommerce,
  .woocommerce-checkout .woocommerce { padding:20px 14px; }
  .woocommerce form.checkout { grid-template-columns:1fr; gap:18px; }
  .woocommerce .cart_totals { max-width:100%; margin:0; }
  .woocommerce .cart-collaterals { justify-content:stretch; }
  .woocommerce-account .woocommerce { grid-template-columns:1fr; padding:20px 14px; }
  .woocommerce-account .woocommerce-MyAccount-navigation { position:static; }
  .woocommerce table.shop_table { font-size:0.84rem; }

  /* Misc */
  .live-chat-btn { bottom:14px; right:14px; width:50px; height:50px; font-size:1.15rem; }
  .back-to-top   { bottom:76px; right:14px; width:37px; height:37px; font-size:0.8rem; }
  .toast         { top:8px; right:8px; left:8px; font-size:0.8rem; padding:10px 13px; }
  .popup-box     { width:93%; }
  .popup-header  { padding:22px 18px; }
  .popup-body    { padding:20px 18px; }
  .sticky-cart-bar { padding:10px 14px; }
  .btn-lg        { padding:13px 24px; font-size:0.88rem; }

  /* Joseph owner card mobile */
  .joseph-card {
    grid-template-columns: 1fr !important;
  }
}

/* Small phones */
@media (max-width: 400px) {
  .hero h1 { font-size:1.5rem; }
  .trust-strip .container { grid-template-columns:1fr; }
  .shipping-grid { grid-template-columns:1fr; }
  .stats-inner { grid-template-columns:1fr 1fr; }
}
