/* ============================================================
   CraftyWorth v2 — Premium Commerce Design System
   WoodMart-grade discipline · Warm gifting identity
   Container · Typography · Spacing · Grid · Commerce utils
   ============================================================ */

/* Global box model + overflow prevention */
*,*::before,*::after{box-sizing:border-box;}
html{overflow-x:hidden;scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{overflow-x:hidden;width:100%;max-width:100vw;}
img,video,iframe,svg,canvas{max-width:100%;height:auto;}
@media (max-width:768px){
  input,select,textarea{font-size:16px !important;-webkit-text-size-adjust:100%;-webkit-appearance:none;}
  /* Container padding capped on mobile */
  .cw-container,.cw-wrap{max-width:100%;padding-left:14px;padding-right:14px;}
  /* Generic tables — scroll horizontally if too wide */
  table:not(.cw-engine-swatches table):not(.variations){display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;}
  .cw-admin-table-wrap,.woocommerce-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  /* Tap targets — minimum 44px for buttons/links acting as buttons */
  button,.button,a.button,[role="button"]{min-height:44px;touch-action:manipulation;}
}

/* ══════════════════════════════════════════════════════════
   1. EXTENDED DESIGN TOKENS
   ══════════════════════════════════════════════════════════ */
:root {
  /* Container widths */
  --cw-max:        1320px;
  --cw-max-md:     1100px;  /* product pages, forms */
  --cw-max-sm:      760px;  /* quote, account content */
  --cw-gutter:      40px;   /* desktop horizontal padding */

  /* Typography scale (fluid) */
  --cw-t-xs:   clamp(10px, 1vw,  11px);
  --cw-t-sm:   clamp(12px, 1.2vw,13px);
  --cw-t-base: clamp(14px, 1.4vw,15px);
  --cw-t-md:   clamp(15px, 1.5vw,16px);
  --cw-t-lg:   clamp(17px, 1.8vw,19px);
  --cw-t-xl:   clamp(20px, 2.2vw,24px);
  --cw-t-2xl:  clamp(24px, 2.8vw,30px);
  --cw-t-3xl:  clamp(28px, 3.5vw,38px);
  --cw-t-4xl:  clamp(34px, 4.5vw,50px);
  --cw-t-hero: clamp(38px, 5.5vw,62px);

  /* Spacing scale */
  --sp-1:   4px;
  --sp-2:   8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;
  --sp-20: 80px;
  --sp-24: 96px;

  /* Section vertical padding */
  --sec-xs:  32px;
  --sec-sm:  48px;
  --sec-md:  64px;
  --sec-lg:  80px;
  --sec-xl:  96px;

  /* Elevations */
  --el-1: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --el-2: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.05);
  --el-3: 0 10px 28px rgba(0,0,0,.10), 0 4px 8px rgba(0,0,0,.05);
  --el-4: 0 20px 48px rgba(0,0,0,.14), 0 8px 16px rgba(0,0,0,.07);

  /* Radius scale */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-pill: 999px;
}

/* ══════════════════════════════════════════════════════════
   2. CONTAINER SYSTEM
   ══════════════════════════════════════════════════════════ */
.cw-container,
.cw-wrap {
  width: 100%;
  max-width: var(--cw-max);
  margin-inline: auto;
  padding-inline: var(--cw-gutter);
}
.cw-container--md  { max-width: var(--cw-max-md); }
.cw-container--sm  { max-width: var(--cw-max-sm); }
.cw-container--full{ max-width: none; padding-inline: 0; }

/* WooCommerce containers use same system */
.woocommerce .woocommerce-notices-wrapper,
.woocommerce-page .woocommerce-notices-wrapper {
  max-width: var(--cw-max);
  margin-inline: auto;
  padding-inline: var(--cw-gutter);
}

/* ══════════════════════════════════════════════════════════
   3. TYPOGRAPHY SYSTEM
   ══════════════════════════════════════════════════════════ */
body {
  font-family: var(--body, 'Manrope', system-ui, sans-serif);
  font-size: var(--cw-t-base);
  line-height: 1.65;
  color: var(--ink, #1A1208);
  -webkit-font-smoothing: antialiased;
}

/* Display headings (serif) */
h1, h2, h3,
.cw-heading-display {
  font-family: var(--head, 'Fraunces', Georgia, serif);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -.02em;
}

h1 { font-size: var(--cw-t-4xl); }
h2 { font-size: var(--cw-t-3xl); }
h3 { font-size: var(--cw-t-2xl); }
h4 { font-size: var(--cw-t-xl); font-family: var(--body); font-weight: 700; }
h5 { font-size: var(--cw-t-lg); font-family: var(--body); font-weight: 700; }
h6 { font-size: var(--cw-t-sm); font-family: var(--body); font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }

/* Body text utilities */
.cw-text-xs   { font-size: var(--cw-t-xs); }
.cw-text-sm   { font-size: var(--cw-t-sm); }
.cw-text-base { font-size: var(--cw-t-base); }
.cw-text-md   { font-size: var(--cw-t-md); }
.cw-text-lg   { font-size: var(--cw-t-lg); }
.cw-text-xl   { font-size: var(--cw-t-xl); }

/* Eyebrow label */
.cw-eyebrow {
  font-size: var(--cw-t-xs);
  font-weight: 700;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--p, #A0293E);
  display: block;
  margin-bottom: var(--sp-2);
}

/* Muted text */
.cw-muted { color: var(--ink-3, #7A6458); }

/* Commerce price — always Fraunces */
.cw-price {
  font-family: var(--head, 'Fraunces', Georgia, serif);
  font-weight: 600;
  color: var(--p, #A0293E);
  line-height: 1;
}

/* ══════════════════════════════════════════════════════════
   4. SPACING UTILITIES
   ══════════════════════════════════════════════════════════ */
.cw-section    { padding-block: var(--sec-lg); }
.cw-section-sm { padding-block: var(--sec-sm); }
.cw-section-xs { padding-block: var(--sec-xs); }
.cw-section-xl { padding-block: var(--sec-xl); }

.cw-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-6);
  margin-bottom: var(--sp-8);
  flex-wrap: wrap;
}
.cw-section-head .cw-see-all {
  font-size: var(--cw-t-sm);
  font-weight: 700;
  color: var(--p);
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════
   5. GRID SYSTEM
   ══════════════════════════════════════════════════════════ */
.cw-grid {
  display: grid;
  gap: var(--sp-5);
}
.cw-grid-2  { grid-template-columns: repeat(2, 1fr); }
.cw-grid-3  { grid-template-columns: repeat(3, 1fr); }
.cw-grid-4  { grid-template-columns: repeat(4, 1fr); }
.cw-grid-5  { grid-template-columns: repeat(5, 1fr); }
.cw-grid-auto { grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr)); }

/* ══════════════════════════════════════════════════════════
   6. BUTTON SYSTEM — Complete overhaul
   ══════════════════════════════════════════════════════════ */
.btn,
.cw-btn,
.button:not(.cw-ham):not(.cw-search-btn):not(.cw-drawer__close) {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--sp-2) !important;
  height: 48px !important;
  padding: 0 var(--sp-6) !important;
  border-radius: var(--radius-pill) !important;
  font-family: var(--body, 'Manrope', sans-serif) !important;
  font-size: var(--cw-t-sm) !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  border: 1.5px solid transparent !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  line-height: 1 !important;
  transition: background .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease !important;
  -webkit-appearance: none !important;
}
.btn:hover,
.button:not(.cw-ham):not(.cw-search-btn):not(.cw-drawer__close):hover {
  transform: translateY(-1px) !important;
}

/* Primary */
.btn--primary, .btn.btn--primary,
a.btn--primary,
.single_add_to_cart_button.button,
.wc-proceed-to-checkout .checkout-button {
  background: var(--p, #A0293E) !important;
  color: #fff !important;
  border-color: var(--p, #A0293E) !important;
}
.btn--primary:hover,
.single_add_to_cart_button.button:hover {
  background: var(--p-d, #7A1E2F) !important;
  border-color: var(--p-d, #7A1E2F) !important;
  box-shadow: 0 6px 20px rgba(160,41,62,.28) !important;
}

/* Accent */
.btn--accent, .btn.btn--accent, a.btn--accent {
  background: var(--a, #E8651A) !important;
  color: #fff !important;
  border-color: var(--a, #E8651A) !important;
}
.btn--accent:hover {
  background: var(--a-d, #C04E0E) !important;
  border-color: var(--a-d, #C04E0E) !important;
  box-shadow: 0 6px 20px rgba(232,101,26,.28) !important;
}

/* Ghost */
.btn--ghost, .btn.btn--ghost, a.btn--ghost {
  background: transparent !important;
  color: var(--p, #A0293E) !important;
  border-color: var(--p, #A0293E) !important;
}
.btn--ghost:hover { background: var(--p-l, #FCEEF1) !important; }

/* Outline light (for dark backgrounds) */
.btn--outline-light {
  background: transparent !important;
  color: #fff !important;
  border-color: rgba(255,255,255,.5) !important;
}
.btn--outline-light:hover { border-color: #fff !important; background: rgba(255,255,255,.12) !important; }

/* Sizes */
.btn--sm { height: 38px !important; padding: 0 var(--sp-4) !important; font-size: 12px !important; }
.btn--lg { height: 56px !important; padding: 0 var(--sp-8) !important; font-size: var(--cw-t-md) !important; }
.btn--full { width: 100% !important; }
.btn--icon { width: 48px !important; padding: 0 !important; }

/* Disabled */
.btn[disabled], .button[disabled] {
  opacity: .5 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  transform: none !important;
}

/* ══════════════════════════════════════════════════════════
   7. FORM SYSTEM
   ══════════════════════════════════════════════════════════ */
.cw-form-group { margin-bottom: var(--sp-4); }
.cw-label {
  display: block;
  font-size: var(--cw-t-xs);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3, #7A6458);
  margin-bottom: var(--sp-2);
}
.cw-label .required { color: var(--p); margin-left: 2px; }
.cw-input,
.cw-textarea,
input[type="text"].input-text,
input[type="email"].input-text,
input[type="tel"].input-text,
input[type="password"].input-text,
select.input-text,
textarea.input-text {
  width: 100% !important;
  height: 48px;
  border: 1.5px solid var(--line, #EAD9CC) !important;
  border-radius: var(--radius-md) !important;
  padding: 0 var(--sp-4) !important;
  font-family: var(--body, 'Manrope', sans-serif) !important;
  font-size: var(--cw-t-base) !important;
  color: var(--ink, #1A1208) !important;
  background: #fff !important;
  outline: none !important;
  transition: border-color .18s ease, box-shadow .18s ease !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
}
.cw-textarea,
textarea.input-text {
  height: auto !important;
  min-height: 110px !important;
  padding: var(--sp-3) var(--sp-4) !important;
  resize: vertical !important;
  line-height: 1.6 !important;
}
.cw-input:focus,
.cw-textarea:focus,
input[type="text"].input-text:focus,
input[type="email"].input-text:focus,
input[type="tel"].input-text:focus,
input[type="password"].input-text:focus,
select.input-text:focus,
textarea.input-text:focus {
  border-color: var(--p, #A0293E) !important;
  box-shadow: 0 0 0 3px rgba(160,41,62,.12) !important;
}

/* Upload field */
.cw-upload-box {
  border: 2px dashed var(--line, #EAD9CC);
  border-radius: var(--radius-lg);
  padding: var(--sp-8) var(--sp-4);
  text-align: center;
  background: var(--off, #FEF7F0);
  cursor: pointer;
  transition: border-color .18s, background .18s;
}
.cw-upload-box:hover { border-color: var(--p); background: var(--p-l, #FCEEF1); }
.cw-upload-box__icon { font-size: 32px; display: block; margin-bottom: var(--sp-3); }
.cw-upload-box__label { font-size: var(--cw-t-sm); font-weight: 700; color: var(--p); }
.cw-upload-box__hint  { font-size: var(--cw-t-xs); color: var(--ink-3); margin-top: var(--sp-1); }

/* ══════════════════════════════════════════════════════════
   8. SINGLE PRODUCT LAYOUT — WoodMart-grade
   ══════════════════════════════════════════════════════════ */

/* Full page wrapper */
.single-product { background: var(--white, #fff); }

/* Main 2-column grid — overrides WC defaults */
.single-product div.product {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr) !important;
  gap: 52px !important;
  align-items: start !important;
  max-width: var(--cw-max-md, 1100px) !important;
  margin: var(--sp-8) auto var(--sp-20) !important;
  padding: 0 var(--cw-gutter) !important;
}

/* Gallery — left col, sticky */
.single-product .woocommerce-product-gallery {
  float: none !important;
  width: 100% !important;
  position: sticky !important;
  top: 88px !important;
  max-width: 100% !important;
}

/* Gallery main image */
.woocommerce-product-gallery .flex-viewport,
.woocommerce-product-gallery__image:first-child {
  border-radius: var(--radius-xl) !important;
  overflow: hidden !important;
  aspect-ratio: 1 / 1 !important;
  background: var(--off) !important;
}
.woocommerce-product-gallery .flex-viewport img,
.woocommerce-product-gallery__image:first-child img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Thumbnails */
.flex-control-nav { display: none; }
.flex-control-thumbs {
  display: grid !important;
  grid-template-columns: repeat(5, 1fr) !important;
  gap: var(--sp-2) !important;
  margin-top: var(--sp-3) !important;
  padding: 0 !important;
  list-style: none !important;
}
.flex-control-thumbs li { margin: 0 !important; }
.flex-control-thumbs img {
  border-radius: var(--radius-sm) !important;
  border: 2px solid transparent !important;
  object-fit: cover !important;
  aspect-ratio: 1 !important;
  cursor: pointer !important;
  transition: border-color .15s !important;
  width: 100% !important;
}
.flex-control-thumbs .flex-active img { border-color: var(--p) !important; }
.flex-control-thumbs img:hover { border-color: var(--line) !important; }

/* Summary — right col */
.single-product .summary.entry-summary {
  float: none !important;
  width: 100% !important;
  clear: none !important;
  max-width: 100% !important;
}

/* Product title */
.single-product h1.product_title {
  font-family: var(--head, 'Fraunces', Georgia, serif) !important;
  font-size: clamp(22px, 2.8vw, 34px) !important;
  font-weight: 500 !important;
  line-height: 1.1 !important;
  letter-spacing: -.02em !important;
  color: var(--ink, #1A1208) !important;
  margin: 0 0 var(--sp-3) !important;
}

/* Ratings row */
.single-product .woocommerce-product-rating {
  display: flex !important;
  align-items: center !important;
  gap: var(--sp-2) !important;
  margin-bottom: var(--sp-4) !important;
}
.single-product .star-rating { color: var(--a, #E8651A) !important; }

/* Price */
.single-product .price {
  display: flex !important;
  align-items: baseline !important;
  gap: var(--sp-3) !important;
  flex-wrap: wrap !important;
  margin: var(--sp-4) 0 !important;
}
.single-product .price .amount,
.single-product .price .woocommerce-Price-amount {
  font-family: var(--head, 'Fraunces', Georgia, serif) !important;
  font-size: clamp(26px, 3vw, 36px) !important;
  font-weight: 600 !important;
  color: var(--p, #A0293E) !important;
  line-height: 1 !important;
}
.single-product .price del { font-size: var(--cw-t-lg) !important; color: var(--ink-3) !important; font-family: var(--body) !important; }
.single-product .price ins { text-decoration: none !important; font-style: normal !important; }

/* Short description */
.single-product .woocommerce-product-details__short-description {
  font-size: var(--cw-t-base) !important;
  color: var(--ink-2, #3D2E20) !important;
  line-height: 1.75 !important;
  margin: var(--sp-4) 0 var(--sp-6) !important;
  border-left: 3px solid var(--line, #EAD9CC) !important;
  padding-left: var(--sp-4) !important;
}

/* Variations */
.single-product .variations tr { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.single-product .variations td.label label { font-size: var(--cw-t-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); }
.single-product .variations select {
  height: 46px !important;
  border: 1.5px solid var(--line) !important;
  border-radius: var(--radius-md) !important;
  padding: 0 var(--sp-4) !important;
  font-size: var(--cw-t-base) !important;
  background: #fff !important;
  cursor: pointer !important;
}

/* Quantity + add to cart */
.single-product form.cart {
  display: flex !important;
  align-items: center !important;
  gap: var(--sp-3) !important;
  margin: var(--sp-5) 0 !important;
  flex-wrap: wrap !important;
}
.single-product .quantity {
  display: flex !important;
  align-items: center !important;
  border: 1.5px solid var(--line) !important;
  border-radius: var(--radius-pill) !important;
  overflow: hidden !important;
  height: 52px !important;
  flex-shrink: 0 !important;
}
.single-product .quantity input[type="number"] {
  width: 52px !important;
  height: 52px !important;
  border: 0 !important;
  text-align: center !important;
  font-size: var(--cw-t-md) !important;
  font-weight: 800 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  -moz-appearance: textfield !important;
}
.single-product .quantity input::-webkit-inner-spin-button,
.single-product .quantity input::-webkit-outer-spin-button { -webkit-appearance: none !important; }

/* Meta (SKU, categories) */
.single-product .product_meta {
  font-size: var(--cw-t-sm) !important;
  color: var(--ink-3) !important;
  margin-top: var(--sp-5) !important;
  padding-top: var(--sp-5) !important;
  border-top: 1px solid var(--line-soft, #F2E8DE) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--sp-2) !important;
}
.single-product .product_meta span { display: flex; gap: var(--sp-2); }
.single-product .product_meta a { color: var(--p); font-weight: 600; }

/* Tabs — spans full width */
.single-product .woocommerce-tabs {
  grid-column: 1 / -1 !important;
  margin-top: var(--sp-12) !important;
  max-width: var(--cw-max-md) !important;
  margin-inline: auto !important;
  width: 100% !important;
  padding-inline: var(--cw-gutter) !important;
}
.single-product .woocommerce-tabs ul.tabs {
  display: flex !important;
  border-bottom: 2px solid var(--line, #EAD9CC) !important;
  margin: 0 0 var(--sp-6) !important;
  padding: 0 !important;
  list-style: none !important;
  gap: 0 !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
}
.single-product .woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none; }
.single-product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -2px !important;
  border-radius: 0 !important;
  flex-shrink: 0 !important;
}
.single-product .woocommerce-tabs ul.tabs li a {
  display: block !important;
  padding: var(--sp-3) var(--sp-5) !important;
  font-size: var(--cw-t-sm) !important;
  font-weight: 700 !important;
  color: var(--ink-3) !important;
  text-decoration: none !important;
}
.single-product .woocommerce-tabs ul.tabs li.active {
  border-bottom-color: var(--p) !important;
}
.single-product .woocommerce-tabs ul.tabs li.active a { color: var(--p) !important; }
.single-product .woocommerce-tabs .panel {
  font-size: var(--cw-t-base) !important;
  line-height: 1.75 !important;
  color: var(--ink-2) !important;
  max-width: 720px !important;
}
.single-product .woocommerce-tabs .panel p { margin-bottom: var(--sp-4) !important; }
.single-product .woocommerce-tabs .panel ul { padding-left: var(--sp-5) !important; margin-bottom: var(--sp-4) !important; }
.single-product .woocommerce-tabs .panel li { margin-bottom: var(--sp-2) !important; }
.single-product .woocommerce-tabs .panel h2,
.single-product .woocommerce-tabs .panel h3 { margin-bottom: var(--sp-4) !important; margin-top: var(--sp-6) !important; }

/* Related products — full width */
.single-product .related.products,
.single-product .upsells.products {
  grid-column: 1 / -1 !important;
  max-width: var(--cw-max-md) !important;
  margin-inline: auto !important;
  width: 100% !important;
  padding-inline: var(--cw-gutter) !important;
  margin-top: var(--sp-16) !important;
  padding-top: var(--sp-12) !important;
  border-top: 1px solid var(--line-soft) !important;
}
.single-product .related.products > h2,
.single-product .upsells.products > h2 {
  font-family: var(--head) !important;
  font-size: var(--cw-t-2xl) !important;
  font-weight: 500 !important;
  margin-bottom: var(--sp-6) !important;
}
.single-product .related ul.products,
.single-product .upsells ul.products {
  grid-template-columns: repeat(4, 1fr) !important;
}

/* ══════════════════════════════════════════════════════════
   9. PRODUCT CARD SYSTEM — Consistent heights
   ══════════════════════════════════════════════════════════ */
.cw-card,
.product.type-product {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}
.cw-card__body { flex: 1; display: flex; flex-direction: column; }
.cw-card__title { flex: 1; }
.cw-card__price { margin-top: var(--sp-2); }
.cw-card__cta   { margin-top: auto; padding-top: var(--sp-3); }

/* Product image — consistent 1:1 */
.cw-card__img,
.product.type-product .woocommerce-LoopProduct-link {
  display: block !important;
  aspect-ratio: 1 / 1 !important;
  overflow: hidden !important;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
  background: var(--off) !important;
  position: relative !important;
}

/* ══════════════════════════════════════════════════════════
   10. SECTION BACKGROUNDS — Rhythm system
   ══════════════════════════════════════════════════════════ */
.cw-bg-white  { background: var(--white, #fff); }
.cw-bg-off    { background: var(--off, #FEF7F0); }
.cw-bg-dark   { background: var(--ink, #1A1208); color: #fff; }
.cw-bg-primary{ background: var(--p, #A0293E); color: #fff; }

/* ══════════════════════════════════════════════════════════
   11. TRUST BADGES
   ══════════════════════════════════════════════════════════ */
.cw-trust-bar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--off);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cw-trust-bar__item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-4);
  border-right: 1px solid var(--line);
  transition: background .15s;
}
.cw-trust-bar__item:last-child { border-right: 0; }
.cw-trust-bar__item:hover { background: rgba(160,41,62,.03); }
.cw-trust-bar__icon { flex-shrink: 0; color: var(--p); }
.cw-trust-bar__text strong { display: block; font-size: var(--cw-t-sm); font-weight: 700; }
.cw-trust-bar__text span  { display: block; font-size: var(--cw-t-xs); color: var(--ink-3); margin-top: 1px; }

/* ══════════════════════════════════════════════════════════
   12. RESPONSIVE BREAKPOINTS
   ══════════════════════════════════════════════════════════ */
@media (max-width: 1200px) {
  :root { --cw-gutter: 32px; }
  .cw-grid-4 { grid-template-columns: repeat(3, 1fr); }
  .cw-grid-5 { grid-template-columns: repeat(3, 1fr); }
  .single-product .related ul.products,
  .single-product .upsells ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  .cw-trust-bar { grid-template-columns: repeat(2, 1fr); }
  .cw-trust-bar__item:nth-child(2) { border-right: 0; }
  .cw-trust-bar__item:nth-child(3) { border-right: 1px solid var(--line); }
}

@media (max-width: 1024px) {
  :root { --cw-gutter: 24px; }
  .single-product div.product {
    gap: 36px !important;
    margin: var(--sp-5) auto var(--sp-16) !important;
  }
  .single-product .woocommerce-product-gallery { position: static !important; }
  .cw-grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  :root { --cw-gutter: 16px; }
  .single-product div.product {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .single-product .woocommerce-product-gallery { position: static !important; }
  .single-product form.cart { flex-direction: column; align-items: stretch; }
  .single-product form.cart .btn { width: 100%; justify-content: center; }
  .single-product .related ul.products,
  .single-product .upsells ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .single-product .woocommerce-tabs {
    padding-inline: var(--cw-gutter) !important;
    margin-top: var(--sp-8) !important;
  }
  .cw-grid-2, .cw-grid-3, .cw-grid-4 { grid-template-columns: 1fr 1fr; }
  .cw-trust-bar { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .single-product div.product { padding: 0 var(--cw-gutter) !important; }
  .cw-grid-2 { grid-template-columns: 1fr; }
  .cw-trust-bar { grid-template-columns: 1fr; }
  .cw-trust-bar__item { border-right: 0 !important; }
}

/* ============================================================
   PRODUCT STUDIO COMPATIBILITY SHIM
   Maps old variable names to v2 design system tokens
   ============================================================ */
:root {
  /* Color aliases */
  --color-primary:       var(--p, #A0293E);
  --color-accent:        var(--a, #E8651A);
  --color-accent-hover:  var(--a-d, #C04E0E);
  --color-border:        var(--line, #EAD9CC);
  --color-success:       #1B8E5A;
  --color-text-strong:   var(--ink, #1A1208);
  --color-text-muted:    var(--ink-3, #7A6458);
  --color-text-light:    var(--ink-3, #7A6458);
  --studio-card-bg:      var(--white, #FFFFFF);

  /* Radius aliases */
  --radius-lg:   var(--r-lg, 18px);
  --radius-xl:   var(--r-xl, 24px);
  --radius-2xl:  28px;
  --radius-pill: var(--pill, 999px);

  /* Shadow aliases */
  --shadow-xs:   var(--sh-1);
  --shadow-sm:   var(--sh-2);

  /* Spacing aliases */
  --space-1:  var(--sp-1, 4px);
  --space-2:  var(--sp-2, 8px);
  --space-3:  var(--sp-3, 12px);
  --space-4:  var(--sp-4, 16px);
  --space-5:  var(--sp-5, 20px);
  --space-6:  var(--sp-6, 24px);
  --space-8:  var(--sp-8, 32px);

  /* Typography aliases */
  --text-sm:   var(--cw-t-sm, 13px);
  --text-md:   var(--cw-t-md, 16px);
  --text-lg:   var(--cw-t-lg, 19px);
  --text-xl:   var(--cw-t-xl, 24px);
  --text-2xl:  var(--cw-t-2xl, 30px);
  --text-3xl:  var(--cw-t-3xl, 38px);
  --font-body: var(--body, 'Manrope', system-ui, sans-serif);
  --font-heading: var(--head, 'Fraunces', Georgia, serif);

  /* Header height (sticky header = ~68px + 44px catnav = 112px) */
  --header-h:  112px;
}

/* ============================================================
   GLOBAL UI CONSISTENCY FIXES
   WoodMart-grade spacing + typography enforcement
   ============================================================ */

/* ── WooCommerce notices ── */
.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
  border-radius: var(--radius-md, 12px) !important;
  padding: 14px 20px !important;
  font-size: 14px !important;
  margin-bottom: 20px !important;
  border: 0 !important;
  border-left: 4px solid var(--p, #A0293E) !important;
}
.woocommerce-error  { background: #FEE2E2 !important; border-left-color: #C03434 !important; }
.woocommerce-info   { background: #DBEAFE !important; border-left-color: #2563B8 !important; }
.woocommerce-message{ background: #E3F4EB !important; border-left-color: #1B8E5A !important; }

/* ── Section titles — consistent across entire site ── */
.cw-sh__title,
.section-title,
.related.products h2,
.upsells.products h2,
.cross-sells h2 {
  font-family: var(--head, 'Fraunces', Georgia, serif) !important;
  font-size: clamp(22px, 2.8vw, 34px) !important;
  font-weight: 500 !important;
  letter-spacing: -.02em !important;
  line-height: 1.1 !important;
}

/* ── All site links ── */
a { text-decoration: none; color: inherit; }
a:hover { color: var(--p, #A0293E); }

/* ── Breadcrumbs consistent ── */
.woocommerce-breadcrumb,
.breadcrumb,
.cw-pdp__crumbs,
.cw-product-studio__breadcrumbs {
  font-size: 12px !important;
  color: var(--ink-3, #7A6458) !important;
  margin-bottom: 20px !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
}
.woocommerce-breadcrumb a,
.breadcrumb a { color: var(--p, #A0293E) !important; font-weight: 600 !important; }
.woocommerce-breadcrumb .separator { opacity: .4; margin: 0 2px; }

/* ── Product count + ordering ── */
.woocommerce-result-count { font-size: 13px; color: var(--ink-3); }
.woocommerce-ordering select {
  height: 38px !important;
  border: 1.5px solid var(--line) !important;
  border-radius: var(--pill) !important;
  padding: 0 32px 0 14px !important;
  font-size: 13.5px !important;
  font-family: inherit !important;
  background: #fff !important;
  appearance: none !important;
  cursor: pointer !important;
}

/* ── Star ratings consistent ── */
.star-rating, .woocommerce-product-rating .star-rating {
  color: var(--a, #E8651A) !important;
}

/* ── Stock status ── */
.in-stock  { color: #1B8E5A !important; font-weight: 600 !important; }
.out-of-stock { color: #C03434 !important; font-weight: 600 !important; }

/* ── Qty input ── */
.qty, input.qty {
  text-align: center !important;
  font-weight: 700 !important;
  -moz-appearance: textfield !important;
}
.qty::-webkit-inner-spin-button,
.qty::-webkit-outer-spin-button { -webkit-appearance: none !important; }

/* ── WooCommerce sale flash ── */
.onsale {
  background: var(--a, #E8651A) !important;
  border-radius: var(--pill) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  padding: 4px 10px !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1.4 !important;
}

/* ── Page title (non-shop pages) ── */
.page-title,
.entry-title,
h1.title {
  font-family: var(--head, 'Fraunces', Georgia, serif) !important;
  font-size: clamp(26px, 3.5vw, 44px) !important;
  font-weight: 500 !important;
  letter-spacing: -.02em !important;
  margin-bottom: 24px !important;
}

/* ── Content readability (page.php / blog only, NOT account/shop) ── */
.page-template-default .entry-content,
.single .entry-content {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-2, #3D2E20);
  max-width: 720px;
}
.page-template-default .entry-content p,
.single .entry-content p { margin-bottom: 16px; }
.page-template-default .entry-content h2,
.page-template-default .entry-content h3 { margin: 32px 0 12px; }
/* Product tabs — readable */
.woocommerce-Tabs-panel {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-2, #3D2E20);
  max-width: 700px;
}

/* ── Focus states (accessibility) ── */
*:focus-visible {
  outline: 2px solid var(--p, #A0293E) !important;
  outline-offset: 2px !important;
}
button:focus-visible, a:focus-visible { border-radius: 4px !important; }

/* ============================================================
   MOBILE UX — Critical fixes for India audience
   ============================================================ */
@media (max-width: 768px) {
  /* iOS-friendly 16px input — prevents auto-zoom */
  input[type="text"], input[type="email"],
  input[type="tel"], input[type="password"],
  input[type="number"], input[type="search"],
  input[type="url"], input[type="date"],
  select, textarea {
    font-size: 16px !important;
  }
  /* Tap targets — min 44px height for primary controls */
  .btn, .cw-btn, .cw-hicon, .cw-search-btn,
  .cw-ham, .cw-drawer__close,
  button[type="submit"] {
    min-height: 44px;
  }
  /* Card system */
  .cw-card__title { font-size: 12px !important; min-height: 32px !important; }
  .cw-card__body  { padding: 8px 10px 10px !important; }
  .cw-trust-bar   { grid-template-columns: repeat(2, 1fr) !important; }
  .cw-tile-grid   { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .cw-tile        { padding: 14px !important; }
  .cw-tile h3     { font-size: 14px !important; }
  .single-product .price .amount,
  .single-product .price .woocommerce-Price-amount { font-size: 26px !important; }
  /* Horizontal scroll prevention */
  html, body { overflow-x: hidden !important; max-width: 100% !important; }
  .woocommerce, .woocommerce-page,
  .single-product { overflow-x: hidden !important; }
  body            { padding-bottom: 62px !important; }
  .cw-tabbar      { display: block !important; }

  /* Tappable item spacing — minimum 8px gap */
  .cw-hicons { gap: 8px !important; }
  .cw-drawer__sec a { padding: 12px 0 !important; }

  /* Single product summary breathing room */
  .single-product .summary.entry-summary,
  .cw-product-summary { padding: 0 4px !important; }

  /* Customization form full-width */
  .cw-customization-engine,
  .cw-customization-engine input,
  .cw-customization-engine textarea,
  .cw-customization-engine select,
  .cw-upload-box {
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Sticky CTA safe area */
  .cw-sticky-cta {
    padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
  }
}
@supports (padding: env(safe-area-inset-bottom)) {
  .cw-tabbar { padding-bottom: env(safe-area-inset-bottom) !important; }
  .cw-sticky-cta { padding-bottom: max(12px, env(safe-area-inset-bottom)) !important; }
}

/* ============================================================
   GLOBAL STOCK + SALE BADGE POLISH
   ============================================================ */
.stock.in-stock, .cw-stock-badge--in {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--pill, 999px);
  background: #E3F4EB;
  color: #1B8E5A;
}
.stock.out-of-stock, .cw-stock-badge--out {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--pill, 999px);
  background: #FEE2E2;
  color: #C03434;
}
/* WC ordering select — full-width on mobile shop bar */
@media (max-width: 768px) {
  .woocommerce-ordering { flex: 1; }
  .woocommerce-ordering select { width: 100% !important; }
}

/* ════════════════════════════════════════════════════════════
   GLOBAL MOBILE SAFETY NET — Production hardening
   Last line of defense against overflow + iOS quirks.
   Uses CSS custom properties (--p, --a, --line, --head, --body).
   ════════════════════════════════════════════════════════════ */

/* Prevent horizontal overflow on any descendant */
.cw-container, .cw-section, .cw-hero, .cw-product-row,
.cw-sh, .woocommerce, .woocommerce-page,
[class*="cw-"], [class*="wc-"] {
  max-width: 100%;
  box-sizing: border-box;
}

/* All media responsive */
img, video, iframe, svg, canvas {
  max-width: 100%;
  height: auto;
}

/* Tables never overflow viewport */
table { border-collapse: collapse; max-width: 100%; }

/* Touch: kill 300ms tap delay */
a, button, [role="button"], input, select, textarea {
  touch-action: manipulation;
}

/* Tap highlight — branded */
a, button { -webkit-tap-highlight-color: rgba(160,41,62,.15); }

/* iOS safe-area for fixed bars */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .cw-sticky-cta, .cwpdp__sticky, .cw-tabbar {
    padding-bottom: max(10px, env(safe-area-inset-bottom));
  }
}

@media (max-width: 768px) {
  /* Force all text/email/number inputs to 16px to disable iOS auto-zoom */
  input[type="text"], input[type="email"], input[type="tel"],
  input[type="password"], input[type="number"], input[type="search"],
  input[type="date"], input[type="url"], select, textarea,
  .cw-engine-input, .input-text, .cw-input, .cw-textarea {
    font-size: 16px !important;
    -webkit-appearance: none;
  }

  /* WooCommerce cart/checkout containers may scroll horizontally */
  .woocommerce-cart-form, .woocommerce-checkout-form {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .shop_table { min-width: 280px; }

  /* WC buttons — guaranteed touch target */
  .woocommerce .button, .woocommerce button[type="submit"],
  .woocommerce input[type="submit"] {
    min-height: 48px;
    font-size: 15px !important;
  }

  /* WC notices — readable, wrap long words */
  .woocommerce-message, .woocommerce-error, .woocommerce-info {
    padding: 12px 14px;
    font-size: 13px;
    word-break: break-word;
  }

  /* Breadcrumbs — single-line, ellipsis if long */
  .woocommerce-breadcrumb {
    font-size: 11px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Price — never break onto two lines */
  .woocommerce-Price-amount { white-space: nowrap; }

  /* MyAccount nav — wrap chips */
  .woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
  }
  .woocommerce-account .woocommerce-MyAccount-navigation li {
    flex: 1;
    min-width: 120px;
  }
}

/* Product loop — 2 columns at 480px, gap tightens */
@media (max-width: 480px) {
  .woocommerce ul.products,
  ul.products, .cw-products-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }
}
@media (max-width: 360px) {
  .woocommerce ul.products,
  ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
}

/* Cookie banner — never cover bottom tabbar on mobile */
@media (max-width: 768px) {
  .cw-cookie {
    bottom: 62px;
    padding: 12px 14px;
    font-size: 12px;
  }
  .cw-cookie__inner { gap: 10px; }
  .cw-cookie__text { font-size: 12px; line-height: 1.45; }
}

/* WhatsApp float — move above bottom tabbar */
@media (max-width: 768px) {
  .cw-wa { bottom: 78px; right: 14px; width: 46px; height: 46px; }
}

/* ── Free Shipping Progress Bar (Phase 7) ── */
.cwv2-ship-bar {
    background: var(--off,#FEF7F0); border: 1px solid var(--line);
    border-radius: 10px; padding: 12px 14px; margin-bottom: 16px;
}
.cwv2-ship-bar__msg { font-size: 13px; margin: 0 0 8px; }
.cwv2-ship-bar__msg--done { color: #166534; }
.cwv2-ship-bar__track {
    height: 6px; background: var(--line); border-radius: 999px; overflow: hidden;
}
.cwv2-ship-bar__fill {
    height: 100%; background: linear-gradient(90deg, var(--p,#A0293E), var(--a,#E8651A));
    border-radius: 999px; transition: width .4s ease;
}

/* ── Scroll to top button (Phase 9) ── */
.cwv2-scroll-top {
    position: fixed; bottom: 80px; right: 16px; z-index: 400;
    width: 42px; height: 42px; border-radius: 50%;
    background: var(--p,#A0293E); color: #fff; border: none;
    box-shadow: 0 4px 12px rgba(160,41,62,.35); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transform: translateY(10px);
    transition: opacity .2s, transform .2s;
}
.cwv2-scroll-top:not([hidden]) { opacity: 1; transform: translateY(0); }
.cwv2-scroll-top:hover { background: var(--p-d,#7A1E2F); }
@media (max-width: 768px) { .cwv2-scroll-top { bottom: 72px; right: 12px; width: 38px; height: 38px; } }
