/*
Theme Name: Care & Cure Nutraceuticals
Theme URI: https://careandcure.com
Author: Care & Cure
Author URI: https://careandcure.com
Description: A premium WooCommerce + Elementor theme built for Care & Cure Nutraceuticals. Features health-focused design, customizable homepage sections, manually selectable featured products, full Elementor page builder support, and a 3-column shop grid with 12 products per page.
Version: 7.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: carecure
Tags: e-commerce, woocommerce, elementor, health, nutraceuticals, supplements, wellness, custom-header, custom-footer, full-width-template, translation-ready
WC requires at least: 7.0
WC tested up to: 8.5
*/

/* ============================================
   CSS CUSTOM PROPERTIES
============================================ */
:root {
  /* Brand Colors - Care & Cure Nutraceuticals */
  --color-primary: #1a4731;        /* Deep Forest Green */
  --color-primary-light: #2d6648;  /* Mid Green */
  --color-primary-dark: #0f2e1e;   /* Darkest Green */
  --color-accent: #5cb85c;         /* Health Green */
  --color-accent-dark: #3d9140;
  --color-accent-light: #8ed18e;
  --color-gold: #d4a843;           /* Warm gold for premium feel */
  --color-gold-dark: #b08830;
  --color-white: #ffffff;
  --color-off-white: #f4f8f5;      /* Soft greenish white */
  --color-light-gray: #eef4f0;     /* Mint-tinted background */
  --color-gray: #d5e3da;
  --color-mid-gray: #7a9688;
  --color-dark-gray: #4a6358;
  --color-text: #1c2e26;
  --color-text-light: #3d5a4c;
  --color-border: #d0e4d8;
  --color-success: #22c55e;
  --color-sale: #e05a2b;           /* Earthy orange for sale */
  --color-new: #2b7fc1;

  /* Typography */
  --font-heading: 'Playfair Display', 'Georgia', serif;
  --font-body: 'Nunito', 'Helvetica Neue', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --font-size-base: 15px;
  --font-size-sm: 13px;
  --font-size-xs: 11px;
  --font-size-lg: 17px;
  --font-size-xl: 20px;
  --font-size-2xl: 24px;
  --font-size-3xl: 32px;
  --font-size-4xl: 44px;
  --font-size-5xl: 60px;
  --line-height-base: 1.65;
  --line-height-tight: 1.25;
  --letter-spacing-wide: 0.08em;
  --letter-spacing-wider: 0.15em;

  /* Spacing */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-2xl: 48px;
  --spacing-3xl: 64px;
  --spacing-4xl: 96px;

  /* Layout */
  --container-max: 1320px;
  --container-wide: 1520px;
  --container-narrow: 960px;
  --header-height: 80px;
  --topbar-height: 40px;
  --sidebar-width: 280px;
  --border-radius: 4px;
  --border-radius-lg: 8px;
  --border-radius-xl: 16px;
  --border-radius-full: 100px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.1), 0 2px 4px rgba(0,0,0,0.06);
  --shadow-lg: 0 10px 30px rgba(0,0,0,0.12), 0 4px 10px rgba(0,0,0,0.08);
  --shadow-xl: 0 20px 60px rgba(0,0,0,0.15);
  --shadow-product: 0 4px 20px rgba(0,0,0,0.08);
  --shadow-product-hover: 0 12px 40px rgba(0,0,0,0.16);

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;
  --transition-bounce: 300ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text);
  background-color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

body.elementor-page {
  padding-top: 0 !important;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-base);
}

a:hover { color: var(--color-accent); }

ul, ol { list-style: none; }

button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: var(--line-height-tight);
  color: var(--color-primary);
}

/* ============================================
   UTILITY CLASSES
============================================ */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--spacing-xl);
}

.container-wide {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--spacing-xl);
}

.container-narrow {
  max-width: var(--container-narrow);
  margin: 0 auto;
  padding: 0 var(--spacing-xl);
}

.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

.sr-only { @extend .screen-reader-text; }

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* ============================================
   TOPBAR
============================================ */
.site-topbar {
  background-color: var(--color-primary);
  height: var(--topbar-height);
  display: flex;
  align-items: center;
  font-size: var(--font-size-xs);
  letter-spacing: var(--letter-spacing-wide);
  position: relative;
  z-index: 100;
}

.site-topbar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.topbar-message {
  color: rgba(255,255,255,0.75);
  font-weight: 400;
}

.topbar-message strong {
  color: var(--color-accent);
}

.topbar-links {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}

.topbar-links a {
  color: rgba(255,255,255,0.7);
  font-size: var(--font-size-xs);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: color var(--transition-fast);
}

.topbar-links a:hover {
  color: var(--color-accent);
}

.topbar-links a svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
}

.topbar-currency-lang {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.topbar-select {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.7);
  font-size: var(--font-size-xs);
  letter-spacing: var(--letter-spacing-wide);
  cursor: pointer;
  padding: 0 var(--spacing-xs);
  text-transform: uppercase;
  appearance: none;
  -webkit-appearance: none;
}

.topbar-select option {
  background: var(--color-primary);
  color: var(--color-white);
}

/* ============================================
   HEADER
============================================ */
.site-header {
  background-color: var(--color-white);
  height: var(--header-height);
  display: flex;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: 0 2px 20px rgba(0,0,0,0.06);
  transition: all var(--transition-base);
}

.site-header.scrolled {
  box-shadow: 0 4px 24px rgba(0,0,0,0.1);
  --header-height: 68px;
}

.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--spacing-xl);
  width: 100%;
}

/* Logo */
.site-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.site-logo a {
  display: flex;
  align-items: center;
  gap: 10px;
}

.logo-icon {
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-icon svg {
  width: 20px;
  height: 20px;
  fill: white;
}

.logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.logo-name {
  font-family: var(--font-heading);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-primary);
}

.logo-tagline {
  font-size: 9px;
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-mid-gray);
  font-weight: 500;
}

.custom-logo-link img {
  max-height: 50px;
  width: auto;
}

/* Navigation */
.main-navigation {
  display: flex;
  justify-content: center;
}

.main-navigation ul {
  display: flex;
  align-items: center;
  gap: 0;
}

.main-navigation li {
  position: relative;
}

.main-navigation a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0 16px;
  height: var(--header-height);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-text);
  transition: color var(--transition-fast);
  white-space: nowrap;
  position: relative;
}

.main-navigation a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 3px;
  background: var(--color-accent);
  transition: width var(--transition-base);
}

.main-navigation li:hover > a,
.main-navigation li.current-menu-item > a,
.main-navigation li.current-menu-parent > a {
  color: var(--color-accent);
}

.main-navigation li:hover > a::after,
.main-navigation li.current-menu-item > a::after {
  width: calc(100% - 32px);
}

/* Dropdown menus */
.main-navigation .sub-menu {
  position: absolute;
  top: calc(var(--header-height) - 0px);
  left: 0;
  min-width: 220px;
  background: var(--color-white);
  box-shadow: var(--shadow-lg);
  border-top: 3px solid var(--color-accent);
  border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--transition-base);
  z-index: 1000;
}

.main-navigation li:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.main-navigation .sub-menu li a {
  height: auto;
  padding: 10px 20px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--color-border);
  width: 100%;
}

.main-navigation .sub-menu li a::after { display: none; }
.main-navigation .sub-menu li:last-child a { border-bottom: none; }

/* Nested sub-menu */
.main-navigation .sub-menu .sub-menu {
  top: 0;
  left: 100%;
  border-top: 3px solid var(--color-accent);
}

/* Header Actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.header-search-wrap {
  display: flex;
  align-items: center;
  background: var(--color-light-gray);
  border-radius: var(--border-radius-full);
  padding: 0 var(--spacing-md);
  height: 40px;
  transition: all var(--transition-base);
  border: 2px solid transparent;
}

.header-search-wrap:focus-within {
  background: var(--color-white);
  border-color: var(--color-accent);
  box-shadow: 0 0 0 4px rgba(232,160,32,0.12);
}

.header-search-wrap input {
  border: none;
  background: none;
  outline: none;
  font-size: var(--font-size-sm);
  color: var(--color-text);
  width: 160px;
  font-family: var(--font-body);
}

.header-search-wrap input::placeholder {
  color: var(--color-mid-gray);
}

.header-search-wrap button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  color: var(--color-mid-gray);
  display: flex;
  align-items: center;
  transition: color var(--transition-fast);
}

.header-search-wrap button:hover { color: var(--color-accent); }

.header-action-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  border-radius: var(--border-radius);
  color: var(--color-text);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: all var(--transition-fast);
}

.header-action-btn:hover {
  background: var(--color-light-gray);
  color: var(--color-accent);
}

.header-action-btn svg {
  width: 22px;
  height: 22px;
}

.action-badge {
  position: absolute;
  top: 0px;
  right: 0px;
  width: 18px;
  height: 18px;
  background: var(--color-accent);
  color: var(--color-white);
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transform: translate(20%, -20%);
}

.header-cart-btn {
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: 600;
  letter-spacing: 0.04em;
  transition: all var(--transition-base);
  position: relative;
  white-space: nowrap;
}

.header-cart-btn:hover {
  background: var(--color-accent);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(232,160,32,0.35);
}

.header-cart-btn svg {
  width: 18px;
  height: 18px;
}

.cart-count-badge {
  background: var(--color-accent);
  color: var(--color-primary);
  font-size: 10px;
  font-weight: 800;
  padding: 1px 6px;
  border-radius: var(--border-radius-full);
  min-width: 20px;
  text-align: center;
}

/* Mobile Menu Toggle */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  color: var(--color-text);
  flex-direction: column;
  gap: 5px;
  transition: all var(--transition-fast);
}

.menu-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: currentColor;
  transition: all var(--transition-base);
  transform-origin: center;
}

.menu-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.menu-toggle.active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.menu-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ============================================
   MINI CART OFFCANVAS
============================================ */
.mini-cart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition-base);
  backdrop-filter: blur(2px);
}

.mini-cart-overlay.active {
  opacity: 1;
  visibility: visible;
}

.mini-cart-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: 400px;
  height: 100vh;
  background: var(--color-white);
  z-index: 9999;
  transform: translateX(100%);
  transition: transform var(--transition-slow) cubic-bezier(0.25, 0.46, 0.45, 0.94);
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-xl);
}

.mini-cart-panel.active {
  transform: translateX(0);
}

.mini-cart-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-xl);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-primary);
  color: var(--color-white);
}

.mini-cart-header h3 {
  color: var(--color-white);
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
}

.mini-cart-close {
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  padding: 6px;
  border-radius: var(--border-radius);
  transition: all var(--transition-fast);
  display: flex;
}

.mini-cart-close:hover { color: var(--color-white); background: rgba(255,255,255,0.1); }

.mini-cart-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--spacing-xl);
}

.cart-item {
  display: flex;
  gap: var(--spacing-md);
  padding: var(--spacing-md) 0;
  border-bottom: 1px solid var(--color-border);
}

.cart-item:last-child { border-bottom: none; }

.cart-item-img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: var(--border-radius);
  flex-shrink: 0;
  background: var(--color-light-gray);
}

.cart-item-details {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cart-item-name {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}

.cart-item-meta {
  font-size: var(--font-size-xs);
  color: var(--color-mid-gray);
}

.cart-item-price {
  font-weight: 700;
  color: var(--color-primary);
  font-size: var(--font-size-sm);
}

.cart-item-remove {
  align-self: flex-start;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-mid-gray);
  padding: 4px;
  transition: color var(--transition-fast);
  display: flex;
}

.cart-item-remove:hover { color: var(--color-sale); }

.mini-cart-footer {
  padding: var(--spacing-xl);
  border-top: 1px solid var(--color-border);
  background: var(--color-off-white);
}

.cart-subtotal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-lg);
  font-size: var(--font-size-lg);
  font-weight: 600;
}

.cart-subtotal-amount {
  color: var(--color-accent);
  font-size: var(--font-size-xl);
  font-family: var(--font-heading);
}

.mini-cart-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 14px;
  border-radius: var(--border-radius);
  font-size: var(--font-size-sm);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--transition-base);
  margin-bottom: var(--spacing-sm);
  border: 2px solid transparent;
}

.mini-cart-btn-primary {
  background: var(--color-accent);
  color: var(--color-white);
  border-color: var(--color-accent);
}

.mini-cart-btn-primary:hover {
  background: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 15px rgba(232,160,32,0.4);
}

.mini-cart-btn-secondary {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-border);
}

.mini-cart-btn-secondary:hover {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: var(--color-white);
}

/* Empty Cart State */
.mini-cart-empty {
  text-align: center;
  padding: var(--spacing-3xl) var(--spacing-xl);
}

.mini-cart-empty svg {
  width: 64px;
  height: 64px;
  color: var(--color-gray);
  margin: 0 auto var(--spacing-lg);
}

.mini-cart-empty h4 {
  font-size: var(--font-size-xl);
  margin-bottom: var(--spacing-sm);
  color: var(--color-primary);
}

.mini-cart-empty p {
  color: var(--color-mid-gray);
  font-size: var(--font-size-sm);
}

/* ============================================
   BREADCRUMB
============================================ */
.site-breadcrumb {
  background: var(--color-light-gray);
  padding: 12px 0;
  font-size: var(--font-size-sm);
}

.breadcrumb-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
}

.breadcrumb-item {
  color: var(--color-mid-gray);
}

.breadcrumb-item a {
  color: var(--color-mid-gray);
}

.breadcrumb-item a:hover { color: var(--color-accent); }

.breadcrumb-separator {
  color: var(--color-gray);
  font-size: 10px;
}

.breadcrumb-item.current { color: var(--color-text); font-weight: 500; }

/* ============================================
   HERO / BANNER
============================================ */
.hero-section {
  position: relative;
  overflow: hidden;
  background: var(--color-primary);
  min-height: 520px;
  display: flex;
  align-items: center;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background: 
    radial-gradient(ellipse at 20% 50%, rgba(232,160,32,0.15) 0%, transparent 60%),
    linear-gradient(135deg, var(--color-primary) 0%, #162035 50%, #0d1825 100%);
}

.hero-pattern {
  position: absolute;
  inset: 0;
  opacity: 0.04;
  background-image: 
    repeating-linear-gradient(45deg, var(--color-white) 0, var(--color-white) 1px, transparent 0, transparent 50%);
  background-size: 30px 30px;
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 640px;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(232,160,32,0.15);
  border: 1px solid rgba(232,160,32,0.3);
  color: var(--color-accent);
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: var(--border-radius-full);
  margin-bottom: var(--spacing-lg);
}

.hero-title {
  font-family: var(--font-heading);
  font-size: clamp(36px, 5vw, 68px);
  font-weight: 700;
  line-height: 1.05;
  color: var(--color-white);
  margin-bottom: var(--spacing-lg);
  letter-spacing: -0.02em;
}

.hero-title em {
  font-style: normal;
  color: var(--color-accent);
}

.hero-subtitle {
  font-size: var(--font-size-lg);
  color: rgba(255,255,255,0.65);
  margin-bottom: var(--spacing-2xl);
  line-height: 1.6;
}

.hero-cta-group {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 28px;
  border-radius: var(--border-radius);
  font-size: var(--font-size-sm);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--transition-base);
  border: 2px solid transparent;
  text-decoration: none;
  white-space: nowrap;
}

.btn-primary {
  background: var(--color-accent);
  color: var(--color-white);
  border-color: var(--color-accent);
}

.btn-primary:hover {
  background: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(232,160,32,0.4);
  color: var(--color-white);
}

.btn-secondary {
  background: transparent;
  color: var(--color-white);
  border-color: rgba(255,255,255,0.4);
}

.btn-secondary:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--color-white);
  color: var(--color-white);
}

.btn-outline {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn-outline:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.btn-sm { padding: 9px 18px; font-size: var(--font-size-xs); }
.btn-lg { padding: 16px 36px; font-size: var(--font-size-base); }

.hero-sale-badge {
  position: absolute;
  right: 10%;
  top: 50%;
  transform: translateY(-50%);
  width: 140px;
  height: 140px;
  background: var(--color-accent);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.1;
  animation: pulse-badge 2s ease-in-out infinite;
  box-shadow: 0 0 0 8px rgba(232,160,32,0.2), 0 0 0 16px rgba(232,160,32,0.1);
}

@keyframes pulse-badge {
  0%, 100% { transform: translateY(-50%) scale(1); }
  50% { transform: translateY(-50%) scale(1.05); }
}

.hero-sale-badge .sale-pct {
  font-size: 42px;
  font-weight: 900;
  color: var(--color-white);
  font-family: var(--font-heading);
  line-height: 1;
}

.hero-sale-badge .sale-text {
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ============================================
   CATEGORY BANNER SECTION
============================================ */
.categories-section {
  padding: var(--spacing-4xl) 0;
}

.section-header {
  text-align: center;
  margin-bottom: var(--spacing-3xl);
}

.section-eyebrow {
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--spacing-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.section-eyebrow::before,
.section-eyebrow::after {
  content: '';
  display: block;
  width: 30px;
  height: 1px;
  background: var(--color-accent);
}

.section-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-4xl);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.category-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-md);
}

.category-card {
  position: relative;
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  aspect-ratio: 2 / 3;
  cursor: pointer;
  display: block;
}

.category-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,22,40,0.85) 0%, rgba(10,22,40,0.2) 50%, transparent 100%);
  z-index: 1;
  transition: opacity var(--transition-slow);
}

.category-card:hover::before {
  opacity: 0.75;
}

.category-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow) cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.category-card:hover img {
  transform: scale(1.06);
}

.category-card-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--spacing-xl);
  z-index: 2;
  transform: translateY(8px);
  transition: transform var(--transition-base);
}

.category-card:hover .category-card-content {
  transform: translateY(0);
}

.category-card-label {
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 6px;
}

.category-card-name {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: var(--spacing-sm);
  line-height: 1.2;
}

.category-card-count {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,0.65);
  margin-bottom: var(--spacing-md);
}

.category-card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-white);
  opacity: 0;
  transform: translateX(-8px);
  transition: all var(--transition-base);
}

.category-card:hover .category-card-link {
  opacity: 1;
  transform: translateX(0);
}

.category-card-link svg {
  width: 14px;
  height: 14px;
  transition: transform var(--transition-fast);
}

.category-card-link:hover svg { transform: translateX(4px); }

/* ============================================
   PRODUCTS GRID (SHOP)
============================================ */
.shop-layout {
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  gap: var(--spacing-3xl);
  padding: var(--spacing-4xl) 0;
}

.shop-layout.no-sidebar {
  grid-template-columns: 1fr;
}

/* Shop Sidebar */
.shop-sidebar {
  width: var(--sidebar-width);
}

.sidebar-widget {
  margin-bottom: var(--spacing-3xl);
  padding-bottom: var(--spacing-3xl);
  border-bottom: 1px solid var(--color-border);
}

.sidebar-widget:last-child {
  border-bottom: none;
}

.sidebar-widget-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-md);
  border-bottom: 2px solid var(--color-accent);
  display: inline-block;
}

/* Category Filter */
.category-filter-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.category-filter-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  border-radius: var(--border-radius);
  cursor: pointer;
  transition: all var(--transition-fast);
  font-size: var(--font-size-sm);
}

.category-filter-item:hover { background: var(--color-light-gray); color: var(--color-accent); }
.category-filter-item.active { background: var(--color-primary); color: var(--color-white); }

.category-filter-count {
  font-size: var(--font-size-xs);
  color: var(--color-mid-gray);
  background: var(--color-light-gray);
  padding: 2px 8px;
  border-radius: var(--border-radius-full);
}

.category-filter-item.active .category-filter-count {
  background: rgba(255,255,255,0.2);
  color: var(--color-white);
}

/* Price Range Filter */
.price-range-wrap {
  padding: var(--spacing-sm) 0;
}

.price-range-track {
  position: relative;
  height: 4px;
  background: var(--color-gray);
  border-radius: 2px;
  margin: var(--spacing-xl) 0 var(--spacing-lg);
}

.price-range-fill {
  position: absolute;
  height: 100%;
  background: var(--color-accent);
  border-radius: 2px;
}

.price-range-input {
  position: absolute;
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  pointer-events: none;
  height: 100%;
  top: 50%;
  transform: translateY(-50%);
}

.price-range-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  background: var(--color-white);
  border: 3px solid var(--color-accent);
  border-radius: 50%;
  pointer-events: all;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-fast);
}

.price-range-input::-webkit-slider-thumb:hover {
  transform: scale(1.2);
}

.price-display {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.price-display .price-val { color: var(--color-accent); }

/* Color Swatches Filter */
.color-swatches {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.color-swatch {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  position: relative;
  border: 2px solid transparent;
  transition: all var(--transition-fast);
}

.color-swatch::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid var(--color-accent);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.color-swatch:hover::after,
.color-swatch.active::after { opacity: 1; }

/* Size Filter */
.size-options {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.size-option {
  padding: 6px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  font-size: var(--font-size-xs);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-transform: uppercase;
}

.size-option:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.size-option.active {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* Shop Toolbar */
.shop-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-lg) 0;
  margin-bottom: var(--spacing-xl);
  border-bottom: 1px solid var(--color-border);
  gap: var(--spacing-md);
  flex-wrap: wrap;
}

.shop-result-count {
  font-size: var(--font-size-sm);
  color: var(--color-mid-gray);
}

.shop-result-count span { color: var(--color-primary); font-weight: 600; }

.shop-toolbar-right {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.shop-view-toggle {
  display: flex;
  gap: 4px;
}

.view-toggle-btn {
  padding: 7px;
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  cursor: pointer;
  color: var(--color-mid-gray);
  transition: all var(--transition-fast);
  display: flex;
}

.view-toggle-btn:hover,
.view-toggle-btn.active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}

.view-toggle-btn svg { width: 16px; height: 16px; }

.shop-sort-select {
  appearance: none;
  -webkit-appearance: none;
  background: var(--color-white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa0ab' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  padding: 8px 36px 8px 14px;
  font-size: var(--font-size-sm);
  color: var(--color-text);
  cursor: pointer;
  min-width: 180px;
  transition: all var(--transition-fast);
}

.shop-sort-select:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(232,160,32,0.12);
}

/* Active Filters */
.active-filters {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
  flex-wrap: wrap;
}

.active-filter-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--color-primary);
  color: var(--color-white);
  padding: 4px 12px;
  border-radius: var(--border-radius-full);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
}

.active-filter-tag button {
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,0.6);
  padding: 0;
  display: flex;
  align-items: center;
  transition: color var(--transition-fast);
}

.active-filter-tag button:hover { color: var(--color-white); }

.clear-all-filters {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--color-accent);
  cursor: pointer;
  text-decoration: underline;
  background: none;
  border: none;
  padding: 0;
}

/* ============================================
   PRODUCT CARDS
============================================ */
.products-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-xl);
}

.products-grid.cols-4 {
  grid-template-columns: repeat(4, 1fr);
}

.products-grid.list-view {
  grid-template-columns: 1fr;
}

.product-card {
  background: var(--color-white);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  position: relative;
  transition: all var(--transition-base);
  border: 1px solid transparent;
}

.product-card:hover {
  box-shadow: var(--shadow-product-hover);
  border-color: var(--color-border);
  transform: translateY(-4px);
}

/* Product Image */
.product-image-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 2 / 3;
  background: var(--color-light-gray);
}

.product-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all var(--transition-slow) cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.product-card:hover .product-image-wrap img {
  transform: scale(1.05);
}

/* Second image on hover */
.product-image-secondary {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity var(--transition-slow);
}

.product-card:hover .product-image-secondary { opacity: 1; }

/* Product Badges */
.product-badges {
  position: absolute;
  top: var(--spacing-md);
  left: var(--spacing-md);
  display: flex;
  flex-direction: column;
  gap: 6px;
  z-index: 2;
}

.product-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--border-radius);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1;
}

.badge-sale { background: var(--color-sale); color: var(--color-white); }
.badge-new { background: var(--color-new); color: var(--color-white); }
.badge-featured { background: var(--color-accent); color: var(--color-white); }
.badge-out-of-stock { background: var(--color-dark-gray); color: var(--color-white); }

/* Quick Action Buttons */
.product-quick-actions {
  position: absolute;
  top: var(--spacing-md);
  right: var(--spacing-md);
  display: flex;
  flex-direction: column;
  gap: 6px;
  z-index: 2;
  transform: translateX(50px);
  transition: transform var(--transition-base);
}

.product-card:hover .product-quick-actions {
  transform: translateX(0);
}

.product-quick-actions .quick-action-btn:nth-child(1) { transition-delay: 0ms; }
.product-quick-actions .quick-action-btn:nth-child(2) { transition-delay: 50ms; }
.product-quick-actions .quick-action-btn:nth-child(3) { transition-delay: 100ms; }

.quick-action-btn {
  width: 38px;
  height: 38px;
  background: var(--color-white);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-text);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-fast);
  position: relative;
}

.quick-action-btn:hover {
  background: var(--color-primary);
  color: var(--color-white);
  transform: scale(1.1);
}

.quick-action-btn.active {
  background: var(--color-sale);
  color: var(--color-white);
}

.quick-action-btn svg { width: 16px; height: 16px; }

/* Tooltip */
.quick-action-btn::before {
  content: attr(data-tooltip);
  position: absolute;
  right: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.04em;
  white-space: nowrap;
  padding: 4px 8px;
  border-radius: var(--border-radius);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-fast);
}

.quick-action-btn:hover::before { opacity: 1; }

/* Add to Cart Overlay */
.product-add-to-cart-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  transform: translateY(100%);
  transition: transform var(--transition-base);
  padding: var(--spacing-sm);
}

.product-card:hover .product-add-to-cart-overlay {
  transform: translateY(0);
}

.product-add-to-cart-btn {
  width: 100%;
  padding: 12px;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  cursor: pointer;
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all var(--transition-fast);
  border-radius: var(--border-radius);
}

.product-add-to-cart-btn:hover {
  background: var(--color-accent);
}

.product-add-to-cart-btn svg { width: 16px; height: 16px; }

/* Product Info */
.product-info {
  padding: var(--spacing-lg);
}

.product-category-tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-mid-gray);
  margin-bottom: 6px;
}

.product-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--spacing-sm);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.product-title a {
  color: inherit;
  transition: color var(--transition-fast);
}

.product-title a:hover { color: var(--color-accent); }

/* Star Rating */
.product-rating {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: var(--spacing-sm);
}

.stars {
  display: flex;
  gap: 2px;
}

.stars svg {
  width: 12px;
  height: 12px;
  color: var(--color-accent);
}

.stars svg.empty { color: var(--color-gray); }

.rating-count {
  font-size: var(--font-size-xs);
  color: var(--color-mid-gray);
}

/* Product Price */
.product-price-wrap {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-sm);
}

.product-price {
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: var(--color-primary);
  font-family: var(--font-heading);
}

.product-price-original {
  font-size: var(--font-size-base);
  color: var(--color-mid-gray);
  text-decoration: line-through;
  font-weight: 400;
}

.product-price-sale {
  color: var(--color-sale);
}

.product-price-savings {
  font-size: 10px;
  font-weight: 700;
  background: rgba(239,68,68,0.1);
  color: var(--color-sale);
  padding: 2px 8px;
  border-radius: var(--border-radius-full);
}

/* Color Variants */
.product-variants {
  display: flex;
  gap: 6px;
  margin-top: var(--spacing-sm);
  flex-wrap: wrap;
}

.variant-swatch {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  cursor: pointer;
  border: 1px solid transparent;
  position: relative;
  transition: all var(--transition-fast);
}

.variant-swatch::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 2px solid transparent;
  transition: border-color var(--transition-fast);
}

.variant-swatch:hover::after { border-color: var(--color-dark-gray); }
.variant-swatch.active::after { border-color: var(--color-primary); }

/* List View Product Card */
.products-grid.list-view .product-card {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 0;
}

.products-grid.list-view .product-image-wrap {
  aspect-ratio: 2 / 3;
}

.products-grid.list-view .product-info {
  padding: var(--spacing-xl);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.products-grid.list-view .product-title { font-size: var(--font-size-2xl); }

.products-grid.list-view .product-description {
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  margin: var(--spacing-md) 0;
  display: block;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
}

/* ============================================
   PAGINATION
============================================ */
.shop-pagination {
  margin-top: var(--spacing-4xl);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-sm);
}

.pagination-btn {
  min-width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--border-radius);
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  padding: 0 var(--spacing-sm);
  text-decoration: none;
}

.pagination-btn:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}

.pagination-btn.active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-white);
  box-shadow: 0 4px 12px rgba(232,160,32,0.35);
}

.pagination-btn.disabled {
  opacity: 0.4;
  pointer-events: none;
}

.pagination-btn svg { width: 16px; height: 16px; }

.pagination-dots {
  color: var(--color-mid-gray);
  padding: 0 4px;
  font-weight: 600;
}

/* ============================================
   FOOTER
============================================ */
.site-footer {
  background: var(--color-primary);
  color: rgba(255,255,255,0.75);
}

.footer-top-bar {
  background: var(--color-accent);
  padding: var(--spacing-xl) 0;
}

.footer-top-bar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-xl);
  flex-wrap: wrap;
}

.footer-newsletter h3 {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  color: var(--color-white);
  margin-bottom: 4px;
}

.footer-newsletter p {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.8);
}

.newsletter-form {
  display: flex;
  gap: 0;
  flex-wrap: wrap;
  min-width: 380px;
}

.newsletter-form input {
  flex: 1;
  padding: 13px 20px;
  border: none;
  background: rgba(255,255,255,0.15);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  border-radius: var(--border-radius) 0 0 var(--border-radius);
  backdrop-filter: blur(10px);
  outline: none;
  min-width: 200px;
  border: 1px solid rgba(255,255,255,0.3);
  border-right: none;
}

.newsletter-form input::placeholder {
  color: rgba(255,255,255,0.6);
}

.newsletter-form input:focus {
  background: rgba(255,255,255,0.25);
}

.newsletter-form button {
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  padding: 13px 24px;
  font-size: var(--font-size-sm);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 0 var(--border-radius) var(--border-radius) 0;
  transition: all var(--transition-base);
  white-space: nowrap;
}

.newsletter-form button:hover {
  background: var(--color-primary-light);
}

/* Footer Main */
.footer-main {
  padding: var(--spacing-4xl) 0 var(--spacing-3xl);
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: var(--spacing-2xl);
}
.cc-footer-grid .footer-col {}
.footer-links { list-style:none; padding:0; margin:0; }
.footer-links li { margin-bottom:8px; }
.footer-links li a,
.footer-links a { color: rgba(255,255,255,.65); text-decoration:none; font-size:14px; transition:color .15s; display:block; }
.footer-links li a:hover,
.footer-links a:hover { color:#fff; }
.footer-logo-text { font-size:22px; font-weight:900; color:var(--cc-green,#8dc63f); }
.footer-logo-img { max-height:50px; width:auto; }

.footer-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--spacing-lg);
  text-decoration: none;
}

.footer-logo .logo-name { color: var(--color-white); }
.footer-logo .logo-tagline { color: rgba(255,255,255,0.4); }

.footer-about {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.55);
  line-height: 1.75;
  margin-bottom: var(--spacing-xl);
  max-width: 280px;
}

.footer-social {
  display: flex;
  gap: var(--spacing-sm);
}

.social-link {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.6);
  transition: all var(--transition-base);
  border: 1px solid rgba(255,255,255,0.1);
}

.social-link:hover {
  background: var(--color-accent);
  color: var(--color-white);
  border-color: var(--color-accent);
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(232,160,32,0.35);
  color: var(--color-white);
}

.social-link svg { width: 16px; height: 16px; }

.footer-widget-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: var(--spacing-xl);
  position: relative;
  padding-bottom: var(--spacing-md);
}

.footer-widget-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 32px;
  height: 2px;
  background: var(--color-accent);
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-links a {
  color: rgba(255,255,255,0.55);
  font-size: var(--font-size-sm);
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 8px;
}

.footer-links a::before {
  content: '';
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-accent);
  flex-shrink: 0;
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.footer-links a:hover {
  color: var(--color-white);
  padding-left: 8px;
}

.footer-links a:hover::before { opacity: 1; }

/* Contact Info */
.footer-contact-items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.55);
}

.contact-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--border-radius);
  background: rgba(232,160,32,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-accent);
}

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

.footer-contact-item a {
  color: rgba(255,255,255,0.7);
}

.footer-contact-item a:hover { color: var(--color-accent); }

/* Payment Methods */
.footer-payment {
  margin-top: var(--spacing-xl);
}

.payment-label {
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  margin-bottom: var(--spacing-sm);
}

.payment-icons {
  display: flex;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}

.payment-icon {
  height: 28px;
  padding: 4px 10px;
  background: rgba(255,255,255,0.1);
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.04em;
  border: 1px solid rgba(255,255,255,0.08);
}

/* Footer Bottom */
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: var(--spacing-xl) 0;
}

.footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-lg);
  flex-wrap: wrap;
}

.footer-copyright {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.4);
}

.footer-copyright a {
  color: var(--color-accent);
}

.footer-bottom-links {
  display: flex;
  gap: var(--spacing-xl);
}

.footer-bottom-links a {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.04em;
}

.footer-bottom-links a:hover { color: var(--color-white); }

/* ============================================
   WOOCOMMERCE OVERRIDES
============================================ */
.woocommerce-notices-wrapper { margin-bottom: var(--spacing-xl); }

/* WC Product Loop */
/* ── Product grid: nuke ALL WooCommerce float/clear/width overrides ── */
ul.products,
ul.products.columns-1,
ul.products.columns-2,
ul.products.columns-3,
ul.products.columns-4,
ul.products.columns-5,
ul.products.columns-6 {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--spacing-xl) !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
  width: 100% !important;
}

/* 4-col only when explicitly set */
ul.products.shopelite-cols-4 {
  grid-template-columns: repeat(4, 1fr) !important;
}

/* Every li must be a clean grid cell — .first and .last get same treatment */
ul.products li.product,
ul.products li.product.first,
ul.products li.product.last {
  background: var(--color-white);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  position: relative;
  transition: all var(--transition-base);
  border: 1px solid transparent;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: none !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

ul.products li.product:hover {
  box-shadow: var(--shadow-product-hover);
  border-color: var(--color-border);
  transform: translateY(-4px);
}

/*
 * Product image — 2:3 portrait ratio to match 1024x1536px uploads.
 * object-fit: contain keeps full bottle visible with subtle bg fill.
 * No fixed height — ratio drives the box size.
 */
ul.products li.product a img,
ul.products li.product .attachment-woocommerce_thumbnail,
ul.products li.product .wp-post-image {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 2 / 3 !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #f4f8f5 !important;
  padding: 16px !important;
  box-sizing: border-box !important;
  transition: transform var(--transition-slow) !important;
}

ul.products li.product:hover a img {
  transform: scale(1.04);
}

ul.products li.product h2.woocommerce-loop-product__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-lg) !important;
  font-weight: 600;
  color: var(--color-primary);
  padding: var(--spacing-md) var(--spacing-lg) 0 !important;
  line-height: 1.3;
}

ul.products li.product .price {
  display: block !important;
  padding: 6px var(--spacing-lg) var(--spacing-md) !important;
  font-family: var(--font-heading) !important;
}

ul.products li.product .price .amount {
  color: var(--color-primary) !important;
  font-size: var(--font-size-xl) !important;
  font-weight: 700 !important;
}

ul.products li.product .price del .amount {
  color: var(--color-mid-gray) !important;
  font-size: var(--font-size-base) !important;
  font-weight: 400 !important;
}

ul.products li.product .price ins {
  text-decoration: none !important;
}

ul.products li.product .price ins .amount {
  color: var(--color-sale) !important;
}

ul.products li.product .button {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: calc(100% - var(--spacing-xl));
  margin: 0 var(--spacing-md) var(--spacing-md) var(--spacing-md) !important;
  padding: 10px !important;
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--border-radius) !important;
  font-size: var(--font-size-xs) !important;
  font-weight: 700 !important;
  letter-spacing: var(--letter-spacing-wide) !important;
  text-transform: uppercase !important;
  transition: all var(--transition-base) !important;
  cursor: pointer;
  text-decoration: none !important;
}

ul.products li.product .button:hover {
  background: var(--color-accent) !important;
  color: var(--color-white) !important;
  transform: none !important;
}

/* WC Badges */
ul.products li.product .onsale {
  background: var(--color-sale) !important;
  border-radius: var(--border-radius) !important;
  font-weight: 700 !important;
  font-size: 10px !important;
  padding: 4px 10px !important;
  min-width: auto !important;
  min-height: auto !important;
  line-height: 1 !important;
  top: var(--spacing-md) !important;
  left: var(--spacing-md) !important;
}

/* WC Pagination */
.woocommerce-pagination {
  margin-top: var(--spacing-4xl) !important;
  text-align: center !important;
}

.woocommerce-pagination ul {
  display: inline-flex !important;
  gap: var(--spacing-sm) !important;
  list-style: none !important;
  padding: 0 !important;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  min-width: 42px;
  height: 42px;
  display: flex !important;
  align-items: center;
  justify-content: center;
  border-radius: var(--border-radius) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: 600 !important;
  cursor: pointer;
  transition: all var(--transition-fast) !important;
  background: var(--color-white) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  text-decoration: none !important;
}

.woocommerce-pagination ul li a:hover {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-white) !important;
}

.woocommerce-pagination ul li span.current {
  background: var(--color-accent) !important;
  border-color: var(--color-accent) !important;
  color: var(--color-white) !important;
}

/* WC Shop Page Result Count & Ordering */
.woocommerce-result-count {
  font-size: var(--font-size-sm) !important;
  color: var(--color-mid-gray) !important;
}

.woocommerce-ordering select {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--border-radius) !important;
  padding: 8px 36px 8px 14px !important;
  font-size: var(--font-size-sm) !important;
  color: var(--color-text) !important;
  background: var(--color-white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa0ab' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center !important;
  cursor: pointer;
  font-family: var(--font-body) !important;
}

/* WC Notices */
.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
  border-radius: var(--border-radius-lg) !important;
  padding: var(--spacing-lg) var(--spacing-xl) !important;
  border-left-width: 4px !important;
}

.woocommerce-message {
  border-color: var(--color-success) !important;
  background: rgba(34,197,94,0.06) !important;
}

.woocommerce-info {
  border-color: var(--color-new) !important;
  background: rgba(59,130,246,0.06) !important;
}

.woocommerce-error {
  border-color: var(--color-sale) !important;
  background: rgba(239,68,68,0.06) !important;
}

/* Single Product */
div.product .woocommerce-product-gallery__wrapper img {
  border-radius: var(--border-radius-lg) !important;
}

div.product .product_title {
  font-family: var(--font-heading) !important;
  font-size: 36px !important;
  font-weight: 700 !important;
  color: var(--color-primary) !important;
  line-height: 1.2 !important;
}

div.product .price {
  font-family: var(--font-heading) !important;
  color: var(--color-primary) !important;
  font-size: 28px !important;
  font-weight: 700 !important;
}

div.product .single_add_to_cart_button {
  background: var(--color-accent) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--border-radius) !important;
  padding: 14px 32px !important;
  font-size: var(--font-size-sm) !important;
  font-weight: 700 !important;
  letter-spacing: var(--letter-spacing-wide) !important;
  text-transform: uppercase !important;
  transition: all var(--transition-base) !important;
  cursor: pointer !important;
}

div.product .single_add_to_cart_button:hover {
  background: var(--color-accent-dark) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(232,160,32,0.4) !important;
}

/* ============================================
   ELEMENTOR COMPATIBILITY
============================================ */
.elementor-page .site-header,
.elementor-page .site-topbar {
  position: relative !important;
}

/* Full Page Template */
.elementor-full-width {
  padding: 0 !important;
  margin: 0 !important;
  max-width: none !important;
}

.page-template-elementor-full-width .site-header {
  position: sticky;
  top: 0;
  z-index: 999;
}

.page-template-elementor-full-width #content,
.page-template-elementor-full-width .site-main {
  padding: 0;
  margin: 0;
}

.page-template-elementor-full-width #primary {
  width: 100%;
  max-width: none;
  padding: 0;
}

.elementor-section-boxed > .elementor-container {
  max-width: var(--container-max);
}

/* ============================================
   FEATURE STRIPS
============================================ */
.features-strip {
  background: var(--color-off-white);
  padding: var(--spacing-2xl) 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-xl);
}

.feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.feature-icon {
  width: 52px;
  height: 52px;
  background: var(--color-white);
  border-radius: var(--border-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
  color: var(--color-accent);
}

.feature-icon svg { width: 24px; height: 24px; }

.feature-text h4 {
  font-size: var(--font-size-base);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 2px;
}

.feature-text p {
  font-size: var(--font-size-xs);
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ============================================
   PROMO BANNERS
============================================ */
.promo-banners {
  padding: var(--spacing-3xl) 0;
}

.promo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-md);
}

.promo-banner {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius-lg);
  min-height: 280px;
  display: flex;
  align-items: center;
  padding: var(--spacing-3xl);
  background: var(--color-primary);
  cursor: pointer;
}

.promo-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(10,22,40,0.9) 0%, rgba(10,22,40,0.4) 100%);
  z-index: 1;
}

.promo-banner-bg {
  position: absolute;
  inset: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: transform var(--transition-slow);
}

.promo-banner:hover .promo-banner-bg {
  transform: scale(1.05);
}

.promo-content {
  position: relative;
  z-index: 2;
}

.promo-eyebrow {
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--spacing-sm);
}

.promo-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-3xl);
  color: var(--color-white);
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: var(--spacing-md);
}

.promo-desc {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.65);
  margin-bottom: var(--spacing-xl);
}

/* ============================================
   LOADING SKELETON
============================================ */
.skeleton {
  background: linear-gradient(90deg, var(--color-light-gray) 25%, var(--color-border) 50%, var(--color-light-gray) 75%);
  background-size: 200% 100%;
  animation: skeleton-loading 1.5s ease-in-out infinite;
  border-radius: var(--border-radius);
}

@keyframes skeleton-loading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ============================================
   BACK TO TOP
============================================ */
.back-to-top {
  position: fixed;
  bottom: 32px;
  right: 32px;
  width: 48px;
  height: 48px;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border: none;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(16px);
  transition: all var(--transition-base);
  z-index: 100;
}

.back-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--color-accent);
  transform: translateY(-4px);
}

.back-to-top svg { width: 20px; height: 20px; }

/* ============================================
   RESPONSIVE
============================================ */
@media (max-width: 1200px) {
  .category-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--spacing-2xl); }
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-sale-badge { width: 110px; height: 110px; right: 5%; }
  .hero-sale-badge .sale-pct { font-size: 32px; }
}

@media (max-width: 1024px) {
  .shop-layout { grid-template-columns: 240px 1fr; gap: var(--spacing-2xl); }
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  ul.products { grid-template-columns: repeat(2, 1fr) !important; }
  .main-navigation { display: none; }
  .menu-toggle { display: flex; }
  .header-search-wrap { display: none; }
  .hero-sale-badge { display: none; }
}

@media (max-width: 768px) {
  :root {
    --container-max: 100%;
    --spacing-4xl: 64px;
    --spacing-3xl: 48px;
  }
  
  .container, .container-wide { padding: 0 var(--spacing-lg); }
  
  .site-topbar .container { flex-direction: column; gap: 4px; text-align: center; }
  .topbar-links { gap: var(--spacing-md); }
  
  .hero-section { min-height: 420px; padding: var(--spacing-3xl) 0; }
  
  .shop-layout { grid-template-columns: 1fr; }
  .shop-sidebar { width: 100%; }
  
  .products-grid { grid-template-columns: repeat(2, 1fr); gap: var(--spacing-md); }
  ul.products { grid-template-columns: repeat(2, 1fr) !important; }
  
  .promo-grid { grid-template-columns: 1fr; }
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-top-bar .container { flex-direction: column; align-items: flex-start; }
  .newsletter-form { min-width: auto; width: 100%; }
  
  .mini-cart-panel { width: 100%; }
  
  .promo-title { font-size: var(--font-size-2xl); }
  
  .section-title { font-size: var(--font-size-3xl); }
}

@media (max-width: 480px) {
  .products-grid { grid-template-columns: 1fr; }
  ul.products { grid-template-columns: 1fr !important; }
  .category-grid { grid-template-columns: 1fr 1fr; gap: var(--spacing-sm); }
  .features-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .header-inner { grid-template-columns: auto 1fr auto; }
  .logo-tagline { display: none; }
}

/* ============================================
   ANIMATIONS
============================================ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideInRight {
  from { transform: translateX(100%); }
  to { transform: translateX(0); }
}

.animate-fade-up {
  animation: fadeInUp 0.6s ease forwards;
}

.animate-fade {
  animation: fadeIn 0.5s ease forwards;
}

/* Stagger animation for product cards */
.products-grid .product-card:nth-child(1) { animation-delay: 0ms; }
.products-grid .product-card:nth-child(2) { animation-delay: 60ms; }
.products-grid .product-card:nth-child(3) { animation-delay: 120ms; }
.products-grid .product-card:nth-child(4) { animation-delay: 180ms; }
.products-grid .product-card:nth-child(5) { animation-delay: 240ms; }
.products-grid .product-card:nth-child(6) { animation-delay: 300ms; }

/* Print styles */
@media print {
  .site-header, .site-footer, .mini-cart-panel, .back-to-top { display: none; }
}

/* ============================================
   CARE & CURE NUTRACEUTICALS — BRAND SPECIFIC
============================================ */

/* Hero inner grid */
.hero-inner-grid {
  display: grid;
  grid-template-columns: 1fr 480px;
  align-items: center;
  gap: var(--spacing-4xl);
  min-height: 500px;
}

/* Hero stats */
.hero-stats {
  display: flex;
  align-items: center;
  gap: var(--spacing-xl);
  margin: var(--spacing-xl) 0 var(--spacing-2xl);
  padding: var(--spacing-lg) var(--spacing-xl);
  background: rgba(255,255,255,0.07);
  border-radius: var(--border-radius-lg);
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  flex-wrap: wrap;
}

.hero-stat {
  display: flex;
  flex-direction: column;
  text-align: center;
}

.hero-stat strong {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--color-accent);
  line-height: 1;
}

.hero-stat span {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 4px;
}

.hero-stat-sep {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,0.15);
}

/* Hero certifications */
.hero-certifications {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: var(--spacing-lg);
}

.cert-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.8);
  padding: 5px 12px;
  border-radius: var(--border-radius-full);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  backdrop-filter: blur(4px);
  transition: all var(--transition-fast);
}

.cert-badge:hover {
  background: rgba(92,184,92,0.2);
  border-color: var(--color-accent);
  color: white;
}

/* Hero visual right side */
.hero-visual {
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-product-showcase {
  position: relative;
  width: 360px;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-product-glow {
  position: absolute;
  inset: -20px;
  background: radial-gradient(circle, rgba(92,184,92,0.25) 0%, transparent 70%);
  border-radius: 50%;
  animation: glow-pulse 3s ease-in-out infinite;
}

@keyframes glow-pulse {
  0%, 100% { opacity: 0.6; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.05); }
}

.hero-product-circle {
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 2px solid rgba(92,184,92,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
}

.hero-product-circle::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(92,184,92,0.15), transparent);
}

.hero-product-icon {
  font-size: 96px;
  animation: float-icon 4s ease-in-out infinite;
  filter: drop-shadow(0 0 30px rgba(92,184,92,0.4));
}

@keyframes float-icon {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

/* Override hero sale badge for nutra brand */
.hero-sale-badge {
  position: absolute;
  bottom: 20px;
  right: -10px;
  width: 110px;
  height: 110px;
  background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.1;
  box-shadow: 0 8px 30px rgba(92,184,92,0.4);
  animation: pulse-badge 2s ease-in-out infinite;
  border: 3px solid rgba(255,255,255,0.2);
}

/* Trust badges grid */
.trust-badges-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-xl);
}

.trust-badge-card {
  background: var(--color-white);
  border-radius: var(--border-radius-lg);
  padding: var(--spacing-2xl) var(--spacing-xl);
  text-align: center;
  border: 1px solid var(--color-border);
  transition: all var(--transition-base);
}

.trust-badge-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-accent);
}

.trust-emoji {
  font-size: 40px;
  margin-bottom: var(--spacing-md);
  display: block;
}

.trust-badge-card h4 {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  color: var(--color-primary);
  margin-bottom: var(--spacing-sm);
}

.trust-badge-card p {
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  line-height: 1.6;
}

/* WooCommerce product cards - portrait 2:3 ratio, consistent background */
ul.products li.product a img,
.product-image-wrap img {
  background: #f4f8f5 !important;
  aspect-ratio: 2 / 3 !important;
  object-fit: contain !important;
  padding: 16px !important;
  box-sizing: border-box !important;
}

/* Green accent for WC add to cart */
ul.products li.product .button,
div.product .single_add_to_cart_button {
  background: var(--color-primary) !important;
}

ul.products li.product .button:hover,
div.product .single_add_to_cart_button:hover {
  background: var(--color-accent) !important;
}

ul.products li.product .onsale {
  background: var(--color-sale) !important;
}

/* Override accent for CTA buttons */
.btn-primary {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-white);
}

.btn-primary:hover {
  background: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
  box-shadow: 0 8px 24px rgba(92,184,92,0.4);
  color: white;
}

/* Section subtitle */
.section-subtitle {
  max-width: 600px;
  margin: var(--spacing-md) auto 0;
  color: var(--color-text-light);
  font-size: var(--font-size-base);
  line-height: 1.7;
}

/* Logo customization */
.logo-icon {
  background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-primary) 100%);
}

/* Header cart btn */
.header-cart-btn {
  background: var(--color-primary);
}

.header-cart-btn:hover {
  background: var(--color-accent);
  box-shadow: 0 4px 12px rgba(92,184,92,0.4);
}

/* Mini cart header */
.mini-cart-header {
  background: var(--color-primary);
}

/* Active filter tags */
.active-filter-tag {
  background: var(--color-primary);
}

/* Footer newsletter bar */
.footer-top-bar {
  background: var(--color-primary);
}

.newsletter-form button {
  background: var(--color-accent);
  color: var(--color-white);
}

.newsletter-form button:hover {
  background: var(--color-accent-dark);
}

/* Mini cart btn */
.mini-cart-btn-primary {
  background: var(--color-accent);
  border-color: var(--color-accent);
}

.mini-cart-btn-primary:hover {
  background: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
  box-shadow: 0 4px 15px rgba(92,184,92,0.4);
}

/* Back to top */
.back-to-top:hover {
  background: var(--color-accent);
}

/* Logo tagline */
.logo-tagline {
  font-size: 9px;
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-mid-gray);
}

/* Topbar */
.site-topbar {
  background-color: var(--color-primary);
}

/* Product price color */
ul.products li.product .price .amount {
  color: var(--color-primary) !important;
}

ul.products li.product .price ins .amount {
  color: var(--color-sale) !important;
}

/* Feature icon */
.feature-icon {
  background: var(--color-off-white);
  color: var(--color-accent);
}

/* Responsive: hero grid */
@media (max-width: 1100px) {
  .hero-inner-grid {
    grid-template-columns: 1fr;
  }
  .hero-visual {
    display: none;
  }
}

@media (max-width: 768px) {
  .trust-badges-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .hero-stats {
    gap: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .trust-badges-grid {
    grid-template-columns: 1fr;
  }
  .hero-certifications {
    justify-content: center;
  }
}

/* ============================================
   ELEMENTOR INTEGRATION STYLES
============================================ */

/* Full-width Elementor pages: remove all content constraints */
.page-template-elementor-full-width #page-content,
.page-template-elementor-full-width .elementor-full-page-wrap,
body.elementor-page #page-content {
  padding: 0 !important;
  margin: 0 !important;
  max-width: none !important;
}

/* Elementor Pro Theme Builder: when it renders header/footer,
   hide the theme's own header/footer */
body.elementor-template-header-footer .site-topbar,
body.elementor-template-header-footer .site-header {
  display: none !important;
}

/* Elementor editor: ensure theme colors apply inside canvas */
.elementor-editor-active .site-wrapper,
.elementor-preview .site-wrapper {
  --color-primary: #1a4731;
  --color-accent: #5cb85c;
}

/* Remove default WP page title on Elementor-built pages */
.elementor-page .page-title-default {
  display: none;
}

/* ============================================
   SINGLE PRODUCT PAGE STYLES
============================================ */
.single-product-page-wrap {
  padding: var(--spacing-3xl) 0;
}

/* WooCommerce single product layout */
.woocommerce div.product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-3xl);
  align-items: start;
}

.woocommerce div.product .woocommerce-product-gallery {
  border-radius: var(--border-radius-xl);
  overflow: hidden;
}

.woocommerce div.product .summary {
  padding: var(--spacing-lg) 0;
}

.woocommerce div.product .product_title {
  font-family: var(--font-heading);
  font-size: var(--font-size-4xl);
  font-weight: 700;
  color: var(--color-text);
  line-height: var(--line-height-tight);
  margin-bottom: var(--spacing-md);
}

.woocommerce div.product .price {
  font-size: var(--font-size-3xl);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--spacing-lg);
}

.woocommerce div.product .price del {
  font-size: var(--font-size-xl);
  color: var(--color-mid-gray);
  font-weight: 400;
  margin-right: 8px;
}

.woocommerce div.product .price ins {
  text-decoration: none;
  color: var(--color-sale);
}

.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: var(--font-size-base);
  color: var(--color-text-light);
  line-height: 1.8;
  margin-bottom: var(--spacing-xl);
  padding-bottom: var(--spacing-xl);
  border-bottom: 1px solid var(--color-border);
}

/* Add to cart button */
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button {
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--border-radius-lg) !important;
  padding: 14px 32px !important;
  font-family: var(--font-body) !important;
  font-size: var(--font-size-base) !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: all var(--transition-base) !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  background: var(--color-accent) !important;
  box-shadow: 0 8px 24px rgba(92,184,92,0.4) !important;
  transform: translateY(-2px) !important;
}

/* Quantity box */
.woocommerce div.product form.cart .qty {
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: 12px 16px;
  font-size: var(--font-size-lg);
  width: 80px;
  text-align: center;
  color: var(--color-text);
}

/* Product tabs */
.woocommerce div.product .woocommerce-tabs {
  margin-top: var(--spacing-3xl);
  grid-column: 1 / -1;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0 0 -1px;
  border-bottom: 2px solid var(--color-border);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  padding: 12px 24px;
  border: 2px solid transparent;
  border-bottom: none;
  cursor: pointer;
  font-weight: 600;
  color: var(--color-text-light);
  border-radius: var(--border-radius) var(--border-radius) 0 0;
  transition: all var(--transition-fast);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active,
.woocommerce div.product .woocommerce-tabs ul.tabs li:hover {
  color: var(--color-primary);
  border-color: var(--color-border);
  background: var(--color-white);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  border-bottom-color: var(--color-white);
}

.woocommerce div.product .woocommerce-tabs .panel {
  padding: var(--spacing-2xl) 0;
  line-height: 1.8;
  color: var(--color-text-light);
}

/* Related products */
.woocommerce .related.products {
  grid-column: 1 / -1;
}

.woocommerce .related.products h2 {
  font-family: var(--font-heading);
  font-size: var(--font-size-3xl);
  color: var(--color-text);
  margin-bottom: var(--spacing-xl);
}

/* Reviews */
.woocommerce #reviews #comments .comment-text {
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: var(--spacing-xl);
}

/* Shop hero bar */
.shop-hero-bar {
  background: var(--color-primary);
  padding: var(--spacing-xl) 0;
  margin-bottom: var(--spacing-2xl);
}

.shop-hero-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-lg);
}

.shop-page-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-3xl);
  color: var(--color-white);
  margin: var(--spacing-sm) 0 0;
  font-weight: 700;
}

.shop-page-desc {
  color: rgba(255,255,255,0.7);
  font-size: var(--font-size-sm);
  margin-top: 6px;
}

.shop-hero-bar .woocommerce-breadcrumb,
.shop-hero-bar .woocommerce-breadcrumb a {
  color: rgba(255,255,255,0.65);
  font-size: var(--font-size-sm);
}

/* No products found */
.no-products-found {
  text-align: center;
  padding: var(--spacing-4xl) 0;
  color: var(--color-text-light);
}

.no-products-found .no-products-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--color-light-gray);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--spacing-xl);
}

.no-products-found .no-products-icon svg {
  width: 36px;
  height: 36px;
  stroke: var(--color-mid-gray);
}

.no-products-found h3 {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  color: var(--color-text);
  margin-bottom: var(--spacing-sm);
}

/* Price filter */
.price-range-inputs {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.price-input-group {
  flex: 1;
}

.price-input-group label {
  display: block;
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-text-light);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}

.price-input-wrap {
  position: relative;
}

.price-input-wrap .currency-symbol {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-light);
  font-size: var(--font-size-sm);
  pointer-events: none;
}

.price-input-wrap input {
  width: 100%;
  padding: 8px 8px 8px 24px;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  font-size: var(--font-size-sm);
  color: var(--color-text);
}

.price-separator {
  color: var(--color-mid-gray);
  margin-top: 20px;
}

/* Sidebar category list */
.sidebar-category-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sidebar-category-list li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  color: var(--color-text-light);
  font-size: var(--font-size-sm);
  border-bottom: 1px solid var(--color-light-gray);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.sidebar-category-list li a:hover,
.sidebar-category-list li.active a {
  color: var(--color-primary);
  font-weight: 600;
}

.sidebar-category-list .cat-count {
  background: var(--color-light-gray);
  color: var(--color-text-light);
  font-size: 11px;
  padding: 2px 7px;
  border-radius: var(--border-radius-full);
}

.sidebar-category-list li.active .cat-count {
  background: var(--color-primary);
  color: white;
}

/* Responsive single product */
@media (max-width: 768px) {
  .woocommerce div.product {
    grid-template-columns: 1fr;
  }
  .shop-hero-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ============================================
   SHOP PAGE — FULL WIDTH, NO SIDEBAR
============================================ */

/* Remove any old sidebar-based layout */
.shop-layout,
.shop-main,
.shop-sidebar {
	all: unset;
}

.carecure-shop-wrap {
	width: 100%;
}

.carecure-container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--spacing-xl);
}

/* Title bar */
.carecure-shop-titlebar {
	background: var(--color-primary);
	padding: var(--spacing-2xl) 0 var(--spacing-xl);
	margin-bottom: var(--spacing-2xl);
}

.carecure-shop-title {
	font-family: var(--font-heading);
	font-size: var(--font-size-4xl);
	color: var(--color-white);
	font-weight: 700;
	margin: 0 0 var(--spacing-sm);
	line-height: var(--line-height-tight);
}

.carecure-shop-titlebar .woocommerce-breadcrumb,
.carecure-shop-titlebar .woocommerce-breadcrumb a {
	color: rgba(255,255,255,0.6);
	font-size: var(--font-size-sm);
}

/* Toolbar */
.carecure-shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--spacing-md) 0;
	margin-bottom: var(--spacing-xl);
	border-bottom: 1px solid var(--color-border);
}

.carecure-toolbar-left .woocommerce-result-count {
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
	margin: 0;
}

.carecure-toolbar-right .woocommerce-ordering select {
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: 8px 12px;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	background: var(--color-white);
	cursor: pointer;
}

/* Force 3-column grid always — no sidebar = full width */
.carecure-shop-wrap ul.products,
.carecure-shop-wrap ul.products.columns-1,
.carecure-shop-wrap ul.products.columns-2,
.carecure-shop-wrap ul.products.columns-3,
.carecure-shop-wrap ul.products.columns-4 {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: var(--spacing-xl) !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 0 var(--spacing-2xl) !important;
	float: none !important;
	clear: none !important;
	width: 100% !important;
}

/* Shop page li — same grid-cell reset */
.carecure-shop-wrap ul.products li.product,
.carecure-shop-wrap ul.products li.product.first,
.carecure-shop-wrap ul.products li.product.last {
	float: none !important;
	clear: none !important;
	margin: 0 !important;
	width: 100% !important;
}

/* No products */
.carecure-no-products {
	text-align: center;
	padding: var(--spacing-4xl) 0;
}

.carecure-no-products-icon {
	font-size: 64px;
	margin-bottom: var(--spacing-md);
}

.carecure-no-products h3 {
	font-family: var(--font-heading);
	font-size: var(--font-size-2xl);
	color: var(--color-text);
	margin-bottom: var(--spacing-sm);
}

.carecure-no-products p {
	color: var(--color-text-light);
	margin-bottom: var(--spacing-xl);
}

/* Pagination */
.carecure-shop-wrap .woocommerce-pagination {
	display: flex;
	justify-content: center;
	margin: var(--spacing-2xl) 0 var(--spacing-4xl);
}

.carecure-shop-wrap .woocommerce-pagination ul {
	display: flex;
	gap: 8px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.carecure-shop-wrap .woocommerce-pagination ul li a,
.carecure-shop-wrap .woocommerce-pagination ul li span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--border-radius);
	border: 1px solid var(--color-border);
	color: var(--color-text);
	font-size: var(--font-size-sm);
	font-weight: 600;
	text-decoration: none;
	transition: all var(--transition-fast);
}

.carecure-shop-wrap .woocommerce-pagination ul li a:hover {
	background: var(--color-primary);
	color: white;
	border-color: var(--color-primary);
}

.carecure-shop-wrap .woocommerce-pagination ul li span.current {
	background: var(--color-primary);
	color: white;
	border-color: var(--color-primary);
}

/* Elementor Pro archive canvas: remove all padding */
.elementor-location-archive .carecure-shop-titlebar,
.elementor-location-archive .carecure-shop-toolbar {
	display: none;
}

/* Responsive */
@media (max-width: 1024px) {
	.carecure-shop-wrap ul.products,
	.carecure-shop-wrap ul.products.columns-3 {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (max-width: 600px) {
	.carecure-shop-wrap ul.products {
		grid-template-columns: 1fr !important;
	}
	.carecure-shop-toolbar {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-sm);
	}
}

/* ════════════════════════════════════════════════════════════
   SINGLE PRODUCT PAGE — CARE & CURE CUSTOM LAYOUT
   Matches the supplement product design reference image
════════════════════════════════════════════════════════════ */

/* ── Page wrapper ── */
.cc-product-page {
	background: #f0f2f5;
	min-height: 100vh;
	padding: 32px 0 64px;
}

.cc-product-container {
	width: 92%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 2%;
}

.cc-product-container .woocommerce-breadcrumb {
	font-size: 12px;
	color: #888;
	margin-bottom: 20px;
}

.cc-product-container .woocommerce-breadcrumb a {
	color: #888;
	text-decoration: none;
}

.cc-product-container .woocommerce-breadcrumb a:hover {
	color: var(--color-primary);
}

/* ── White card wrap ── */
.cc-product-top,
.cc-product-bottom {
	background: #fff;
	border-radius: 12px;
	padding: 32px;
	box-shadow: 0 2px 16px rgba(0,0,0,0.07);
}

.cc-product-top {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: start;
	margin-bottom: 24px;
}

.cc-product-bottom {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 40px;
	align-items: start;
}

/* ── Divider ── */
.cc-divider {
	height: 1px;
	background: #e8eaed;
	margin: 16px 0;
}

/* ═══ LEFT COLUMN: GALLERY ═══ */
.cc-gallery-col {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cc-main-image-wrap {
	position: relative;
	border-radius: 10px;
	overflow: hidden;
	background: #f8f9fa;
	aspect-ratio: 2 / 3;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid #eee;
}

.cc-main-image-wrap a {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}

.cc-main-img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	transition: transform 0.4s ease;
}

.cc-main-image-wrap:hover .cc-main-img {
	transform: scale(1.04);
}

.cc-zoom-icon {
	position: absolute;
	bottom: 12px;
	right: 12px;
	width: 34px;
	height: 34px;
	background: rgba(255,255,255,0.9);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0,0,0,0.15);
	opacity: 0;
	transition: opacity 0.2s;
	pointer-events: none;
}

.cc-zoom-icon svg {
	width: 16px;
	height: 16px;
	stroke: var(--color-primary);
}

.cc-main-image-wrap:hover .cc-zoom-icon {
	opacity: 1;
}

/* Thumbnails */
.cc-thumbnails {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.cc-thumb {
	width: 72px;
	height: 72px;
	border-radius: 8px;
	overflow: hidden;
	border: 2px solid #e0e0e0;
	cursor: pointer;
	transition: border-color 0.2s, transform 0.2s;
	background: #f8f9fa;
	flex-shrink: 0;
}

.cc-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cc-thumb:hover,
.cc-thumb.active {
	border-color: var(--color-primary);
	transform: translateY(-2px);
}

/* ═══ RIGHT COLUMN: SUMMARY ═══ */
.cc-summary-col {
	padding-top: 4px;
}

.cc-product-category {
	font-size: 12px;
	color: #888;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: 8px;
	font-weight: 500;
}

.cc-product-title {
	font-family: var(--font-heading);
	font-size: 32px;
	font-weight: 800;
	color: #1a2d4a;
	line-height: 1.2;
	margin: 0 0 4px;
}

.cc-short-intro {
	font-size: 14px;
	color: #555;
	line-height: 1.6;
	margin: 8px 0 0;
}

/* Price */
.cc-price-wrap {
	margin: 12px 0;
}

.cc-price-wrap .price {
	font-size: 22px;
	font-weight: 700;
	color: var(--color-primary) !important;
}

.cc-price-wrap .price del {
	color: #aaa !important;
	font-size: 16px;
	font-weight: 400;
	margin-right: 6px;
}

.cc-price-wrap .price ins {
	text-decoration: none;
	color: var(--color-sale) !important;
}

/* Offer banner */
.cc-offer-banner {
	background: #fff8f0;
	border: 1px solid #f5d0a0;
	border-radius: 8px;
	padding: 12px 16px;
	margin: 12px 0;
	font-size: 14px;
	color: #333;
	line-height: 1.5;
}

.cc-offer-label {
	font-weight: 800;
	color: #c0392b;
	margin-right: 4px;
}

.cc-offer-banner em {
	color: #c0392b;
	font-style: italic;
	font-weight: 600;
}

/* Cart area */
.cc-cart-wrap {
	margin: 16px 0;
}

.cc-cart-wrap form.cart {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

/* Quantity */
.cc-cart-wrap .quantity {
	display: flex;
	align-items: center;
	border: 1px solid #ccc;
	border-radius: 8px;
	overflow: hidden;
	height: 46px;
}

.cc-cart-wrap .quantity input.qty {
	border: none !important;
	width: 52px !important;
	height: 46px !important;
	text-align: center;
	font-size: 16px;
	font-weight: 700;
	color: var(--color-text);
	background: transparent;
	padding: 0 !important;
	-moz-appearance: textfield;
}

.cc-cart-wrap .quantity input.qty::-webkit-inner-spin-button,
.cc-cart-wrap .quantity input.qty::-webkit-outer-spin-button {
	-webkit-appearance: none;
}

/* Qty +/- buttons injected by JS */
.cc-qty-btn {
	width: 40px;
	height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 20px;
	color: #555;
	background: #f5f5f5;
	border: none;
	transition: background 0.15s, color 0.15s;
	user-select: none;
	font-weight: 300;
}

.cc-qty-btn:hover {
	background: var(--color-primary);
	color: #fff;
}

/* Add to Cart button */
.cc-cart-wrap .single_add_to_cart_button {
	flex: 1;
	min-width: 180px;
	background: var(--color-primary) !important;
	color: #fff !important;
	border: none !important;
	border-radius: 8px !important;
	height: 46px !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	letter-spacing: 0.04em !important;
	text-transform: uppercase !important;
	cursor: pointer !important;
	transition: background 0.2s, box-shadow 0.2s, transform 0.15s !important;
	padding: 0 28px !important;
}

.cc-cart-wrap .single_add_to_cart_button:hover {
	background: var(--color-accent) !important;
	box-shadow: 0 6px 20px rgba(92,184,92,0.35) !important;
	transform: translateY(-2px) !important;
}

/* Meta rows (Usage / Ingredients) */
.cc-meta-row {
	display: flex;
	align-items: baseline;
	gap: 8px;
	font-size: 14px;
	line-height: 1.6;
	color: #444;
	padding: 4px 0;
}

.cc-meta-label {
	font-weight: 800;
	color: #1a2d4a;
	white-space: nowrap;
	flex-shrink: 0;
}

.cc-meta-value {
	color: #555;
}

/* ═══ BOTTOM LEFT: CONTENT SECTIONS ═══ */
.cc-content-col {
	padding-right: 8px;
}

.cc-section {
	padding-bottom: 24px;
	margin-bottom: 24px;
	border-bottom: 1px solid #eee;
}

.cc-section:last-child {
	border-bottom: none;
	margin-bottom: 0;
}

.cc-section-heading {
	font-family: var(--font-heading);
	font-size: 20px;
	font-weight: 800;
	color: #1a2d4a;
	margin: 0 0 12px;
	line-height: 1.3;
}

.cc-section-body {
	font-size: 14px;
	color: #555;
	line-height: 1.8;
}

.cc-section-body p {
	margin: 0 0 10px;
}

.cc-section-body p:last-child {
	margin-bottom: 0;
}

/* Benefits — style the UL list with green checkmarks */
.cc-benefits ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.cc-benefits ul li {
	padding: 5px 0 5px 28px;
	position: relative;
	font-size: 14px;
	color: #444;
	line-height: 1.6;
}

.cc-benefits ul li::before {
	content: '✓';
	position: absolute;
	left: 0;
	top: 5px;
	color: var(--color-accent);
	font-weight: 800;
	font-size: 14px;
}

/* Safety warning — subtle red tint */
.cc-safety {
	background: #fff8f7;
	border-left: 3px solid #e05a2b;
	padding: 12px 16px;
	border-radius: 0 6px 6px 0;
	font-size: 14px;
	color: #555;
}

/* ═══ BOTTOM RIGHT: SIDEBAR ═══ */
.cc-sidebar-col {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.cc-sidebar-widget {
	background: #f8f9fa;
	border: 1px solid #e8eaed;
	border-radius: 10px;
	padding: 20px;
}

.cc-sidebar-title {
	font-family: var(--font-heading);
	font-size: 16px;
	font-weight: 800;
	color: #1a2d4a;
	margin: 0 0 14px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--color-primary);
}

/* Article list */
.cc-article-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.cc-article-list li a {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 13px;
	color: var(--color-primary);
	text-decoration: none;
	line-height: 1.5;
	transition: color 0.15s;
}

.cc-article-list li a:hover {
	color: var(--color-accent);
}

.cc-article-bullet {
	color: var(--color-primary);
	font-size: 16px;
	line-height: 1;
	flex-shrink: 0;
	margin-top: 2px;
}

/* Badges */
.cc-badges {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cc-badge-item {
	display: flex;
	align-items: center;
	gap: 14px;
}

.cc-badge-icon {
	width: 52px;
	height: 52px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.cc-badge-icon svg {
	width: 100%;
	height: 100%;
}

.cc-badge-label {
	font-size: 14px;
	font-weight: 700;
	color: #1a2d4a;
}

/* Separator between badge items */
.cc-badge-item + .cc-badge-item {
	padding-top: 16px;
	border-top: 1px solid #e8eaed;
}

/* ═══ RELATED PRODUCTS ═══ */
.cc-related-products {
	margin-top: 32px;
}

.cc-related-heading {
	font-family: var(--font-heading);
	font-size: 26px;
	font-weight: 800;
	color: #1a2d4a;
	margin-bottom: 20px;
}

.cc-related-products ul.products {
	grid-template-columns: repeat(4, 1fr) !important;
}

/* ═══ LIGHTBOX ═══ */
.cc-lightbox {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease;
}

.cc-lightbox.active {
	opacity: 1;
	pointer-events: auto;
}

.cc-lightbox-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.88);
	cursor: zoom-out;
}

.cc-lightbox-content {
	position: relative;
	z-index: 1;
	max-width: 90vw;
	max-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
	transform: scale(0.92);
	transition: transform 0.25s ease;
}

.cc-lightbox.active .cc-lightbox-content {
	transform: scale(1);
}

.cc-lightbox-img {
	max-width: 90vw;
	max-height: 85vh;
	object-fit: contain;
	border-radius: 8px;
	box-shadow: 0 20px 60px rgba(0,0,0,0.5);
	display: block;
}

.cc-lightbox-close {
	position: absolute;
	top: -44px;
	right: -4px;
	width: 36px;
	height: 36px;
	background: rgba(255,255,255,0.15);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.15s;
}

.cc-lightbox-close:hover {
	background: rgba(255,255,255,0.3);
}

.cc-lightbox-close svg {
	width: 18px;
	height: 18px;
	stroke: #fff;
}

/* ═══ WOOCOMMERCE OVERRIDES inside cc-product-page ═══ */

/* Hide WC default tabs structure if we're outputting manually */
.cc-product-page .woocommerce-tabs {
	display: none;
}

/* Hide WC notices default styling if needed */
.cc-product-page .woocommerce-product-gallery {
	display: none; /* We use our own gallery */
}

.cc-product-page form.cart .variations {
	width: 100%;
	margin-bottom: 12px;
}

.cc-product-page form.cart .variations td,
.cc-product-page form.cart .variations th {
	padding: 4px 0;
	font-size: 14px;
}

.cc-product-page form.cart .variations select {
	width: 100%;
	padding: 8px 12px;
	border: 1px solid #ccc;
	border-radius: 6px;
	font-size: 14px;
}

.cc-product-page .out-of-stock {
	color: var(--color-sale);
	font-weight: 700;
	font-size: 14px;
}

/* ═══ RESPONSIVE ═══ */
@media (max-width: 860px) {
	.cc-product-top {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.cc-product-bottom {
		grid-template-columns: 1fr;
	}
	.cc-sidebar-col {
		order: -1; /* sidebar above content on mobile */
	}
	.cc-related-products ul.products {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (max-width: 480px) {
	.cc-product-top,
	.cc-product-bottom {
		padding: 20px;
	}
	.cc-product-title {
		font-size: 24px;
	}
	.cc-cart-wrap form.cart {
		flex-direction: column;
		align-items: stretch;
	}
	.cc-cart-wrap .single_add_to_cart_button {
		width: 100% !important;
	}
}

/* ════════════════════════════════════════════════════════════
   GLOBAL PRODUCT IMAGE RATIO FIX
   Products are 1024×1536px (2:3 portrait). This block ensures
   every context where product images appear uses the correct ratio.
════════════════════════════════════════════════════════════ */

/* Loop cards — shop, archive, homepage featured, related products */
ul.products li.product img,
ul.products li.product a img,
ul.products li.product .woocommerce-loop-product__link img,
.products li.product img,
.woocommerce ul.products li.product img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 2 / 3 !important;
  object-fit: contain !important;
  object-position: center !important;
  background-color: #f4f8f5 !important;
  padding: 16px !important;
  box-sizing: border-box !important;
}

/* Homepage featured products section */
.featured-products-section ul.products li.product img,
.featured-products-section .products li.product img {
  aspect-ratio: 2 / 3 !important;
  object-fit: contain !important;
  padding: 16px !important;
  background-color: #f4f8f5 !important;
}

/* Single product page main image */
.cc-main-img {
  aspect-ratio: 2 / 3;
  object-fit: contain;
  background-color: #f4f8f5;
  width: 100%;
  height: auto;
}

/* Thumbnail strip on single product */
.cc-thumb img {
  aspect-ratio: 2 / 3;
  object-fit: contain;
  background-color: #f4f8f5;
  padding: 4px;
  box-sizing: border-box;
}

/* Related products on single product page (4-col) */
.cc-related-products ul.products li.product img {
  aspect-ratio: 2 / 3 !important;
  object-fit: contain !important;
  padding: 12px !important;
  background-color: #f4f8f5 !important;
}

/* WooCommerce places a clearfix pseudo-element on li.first —
   reset it so it doesn't create an empty grid cell */
ul.products li.product.first::before,
ul.products li.product.first::after,
ul.products li.product.last::before,
ul.products li.product.last::after {
  content: none !important;
  display: none !important;
  clear: none !important;
  float: none !important;
}

/* ====================================================================
   THREE PRODUCT STYLES v8 — % widths, 2/3 ratio, responsive
==================================================================== */
.cc-lightbox{display:none;position:fixed;inset:0;z-index:99999;align-items:center;justify-content:center}
.cc-lightbox.active{display:flex}
.cc-lightbox-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82)}
.cc-lightbox-content{position:relative;z-index:1;max-width:90vw;max-height:90vh}
.cc-lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;display:block}
.cc-lightbox-close{position:absolute;top:-44px;right:0;background:transparent;border:none;cursor:pointer;color:#fff;width:36px;height:36px;display:flex;align-items:center;justify-content:center}
.cc-lightbox-close svg{width:24px;height:24px}
.cc-zoom-icon{position:absolute;bottom:12px;right:12px;width:34px;height:34px;background:rgba(255,255,255,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;pointer-events:none;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.cc-zoom-icon svg{width:16px;height:16px}
*:hover>.cc-zoom-icon{opacity:1}
.cc-qty-btn{width:40px;height:46px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:#555;background:#f5f5f5;border:none;transition:background .15s,color .15s;user-select:none;font-weight:300}
.cc-qty-btn:hover{background:var(--color-primary);color:#fff}
.cc-benefits ul{list-style:none;padding:0;margin:0}
.cc-benefits ul li{padding:5px 0 5px 26px;position:relative;font-size:14px;color:#444;line-height:1.6}
.cc-benefits ul li::before{content:'\2713';position:absolute;left:0;top:5px;color:var(--color-accent);font-weight:800;font-size:14px}
.cc-safety{background:#fff8f7;border-left:3px solid #e05a2b;padding:12px 16px;border-radius:0 6px 6px 0;font-size:14px;color:#555}
.cc-related-products{margin-top:48px;padding-top:32px;border-top:1px solid #e8eaed}
.cc-related-heading{font-family:var(--font-heading);font-size:24px;font-weight:800;color:#1a2d4a;margin:0 0 24px}
.cc-s1-wrap .woocommerce-breadcrumb,.cc-s2-wrap .woocommerce-breadcrumb,.cc-s3-wrap .woocommerce-breadcrumb{font-size:12px;color:#999;margin-bottom:20px}
.cc-s1-wrap .woocommerce-breadcrumb a,.cc-s2-wrap .woocommerce-breadcrumb a,.cc-s3-wrap .woocommerce-breadcrumb a{color:#999}
.cc-s1-cart form.cart,.cc-s2-cart form.cart,.cc-s3-buy-cart form.cart{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.cc-s1-cart .quantity,.cc-s2-cart .quantity,.cc-s3-buy-cart .quantity{display:flex;align-items:center;border:1px solid #ccc;border-radius:8px;overflow:hidden;height:46px}
.cc-s1-cart .quantity input.qty,.cc-s2-cart .quantity input.qty,.cc-s3-buy-cart .quantity input.qty{border:none!important;width:52px!important;height:46px!important;text-align:center;font-size:16px;font-weight:700;color:var(--color-text);background:transparent;padding:0!important;-moz-appearance:textfield}
.cc-s1-cart .single_add_to_cart_button,.cc-s2-cart .single_add_to_cart_button,.cc-s3-buy-cart .single_add_to_cart_button{flex:1;min-width:160px;background:var(--color-primary)!important;color:#fff!important;border:none!important;border-radius:8px!important;height:46px!important;font-size:15px!important;font-weight:700!important;letter-spacing:.04em!important;text-transform:uppercase!important;cursor:pointer!important;transition:background .2s,box-shadow .2s,transform .15s!important;padding:0 24px!important}
.cc-s1-cart .single_add_to_cart_button:hover,.cc-s2-cart .single_add_to_cart_button:hover,.cc-s3-buy-cart .single_add_to_cart_button:hover{background:var(--color-accent)!important;box-shadow:0 6px 20px rgba(92,184,92,.35)!important;transform:translateY(-2px)!important}

/* ── STYLE 1 Thorne-inspired ── */
.cc-style-1{background:#f8faf9;padding:40px 0 80px;min-height:100vh}
.cc-s1-wrap{width:92%;max-width:1400px;margin:0 auto;padding:0 2%}
.cc-s1-hero{display:grid;grid-template-columns:42% 58%;gap:5%;align-items:start;margin-bottom:48px}
.cc-s1-gallery{display:flex;flex-direction:column;gap:16px}
.cc-s1-main-img-wrap{position:relative;border-radius:12px;overflow:hidden;background:#fff;aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;border:1px solid #e8ede9;box-shadow:0 2px 20px rgba(0,0,0,.06)}
.cc-s1-main-img-wrap a{display:block;width:100%;height:100%;position:relative}
.cc-s1-main-img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .4s}
.cc-s1-main-img-wrap:hover .cc-s1-main-img{transform:scale(1.03)}
.cc-s1-thumbs{display:flex;gap:10px;flex-wrap:wrap}
.cc-s1-thumb{width:72px;height:72px;border-radius:8px;overflow:hidden;border:2px solid #dde8e0;cursor:pointer;transition:border-color .2s,transform .2s;background:#f8f9fa;flex-shrink:0}
.cc-s1-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.cc-s1-thumb:hover,.cc-s1-thumb.active{border-color:var(--color-primary);transform:translateY(-2px)}
.cc-s1-summary{padding-top:8px}
.cc-s1-cat{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:10px}
.cc-s1-title{font-family:var(--font-heading);font-size:clamp(22px,3vw,38px);font-weight:800;color:#1a2d4a;line-height:1.2;margin:0 0 12px}
.cc-s1-tagline{font-size:15px;color:#666;line-height:1.6;margin:0 0 16px}
.cc-s1-divider{height:1px;background:#e8ede9;margin:16px 0}
.cc-s1-price .price{font-size:28px!important;font-weight:800!important;color:var(--color-primary)!important}
.cc-s1-price .price del{color:#aaa!important;font-size:17px!important;font-weight:400!important}
.cc-s1-price .price ins{text-decoration:none!important;color:var(--color-sale)!important}
.cc-s1-offer{background:#fff9f0;border:1px solid #f5d88a;border-radius:8px;padding:10px 14px;font-size:13px;color:#b07700;margin:12px 0;font-weight:600}
.cc-s1-offer span{color:#c0392b;font-weight:800;margin-right:4px}
.cc-s1-cart{margin:18px 0}
.cc-s1-trust{display:flex;gap:20px;flex-wrap:wrap;margin:16px 0}
.cc-s1-trust-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#666;font-weight:600}
.cc-s1-trust-item svg{width:18px;height:18px;flex-shrink:0}
.cc-s1-meta{font-size:14px;color:#555;line-height:1.7;margin:8px 0}
.cc-s1-meta strong{color:#1a2d4a;font-weight:700;margin-right:4px}
.cc-s1-tabs-area{background:#fff;border-radius:12px;box-shadow:0 2px 16px rgba(0,0,0,.06);margin-bottom:32px;overflow:hidden}
.cc-s1-tab-nav{display:flex;border-bottom:1px solid #eee;padding:0 8px;overflow-x:auto}
.cc-s1-tab{background:none;border:none;border-bottom:3px solid transparent;padding:16px 20px;font-size:14px;font-weight:700;color:#888;cursor:pointer;transition:color .2s,border-color .2s;white-space:nowrap}
.cc-s1-tab:hover{color:var(--color-primary)}
.cc-s1-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}
.cc-s1-tab-panels{padding:28px 32px}
.cc-s1-panel{display:none;font-size:15px;color:#555;line-height:1.8}
.cc-s1-panel.active{display:block}
.cc-s1-panel h3{font-family:var(--font-heading);font-size:20px;font-weight:800;color:#1a2d4a;margin:0 0 16px}
.cc-s1-wc-below{margin-top:32px}
@media(max-width:900px){.cc-s1-hero{grid-template-columns:1fr;gap:32px}.cc-s1-main-img-wrap{max-width:80%;margin:0 auto}}
@media(max-width:600px){.cc-s1-wrap{width:96%}.cc-s1-main-img-wrap{max-width:100%}.cc-s1-tab-panels{padding:20px 16px}}

/* ── STYLE 2 MyProtein-inspired ── */
.cc-style-2{background:#f5f7f6;padding:40px 0 80px;min-height:100vh}
.cc-s2-wrap{width:92%;max-width:1400px;margin:0 auto;padding:0 2%}
.cc-s2-hero{display:grid;grid-template-columns:50% 50%;gap:4%;align-items:start;margin-bottom:48px}
.cc-s2-gallery{display:flex;flex-direction:row;gap:14px}
.cc-s2-thumblist{display:flex;flex-direction:column;gap:8px;width:80px;flex-shrink:0}
.cc-s2-thumb{width:76px;height:76px;border-radius:6px;overflow:hidden;border:2px solid #dde8e0;cursor:pointer;transition:border-color .2s;background:#fff;flex-shrink:0}
.cc-s2-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.cc-s2-thumb:hover,.cc-s2-thumb.active{border-color:var(--color-primary)}
.cc-s2-main-wrap{flex:1;position:relative;border-radius:12px;overflow:hidden;background:#fff;aspect-ratio:2/3;border:1px solid #dde8e0;box-shadow:0 4px 20px rgba(0,0,0,.08)}
.cc-s2-main-wrap a{display:block;width:100%;height:100%;position:relative}
.cc-s2-main-img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .4s}
.cc-s2-main-wrap:hover .cc-s2-main-img{transform:scale(1.03)}
.cc-s2-summary{position:sticky;top:100px;background:#fff;border-radius:12px;padding:28px;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.cc-s2-cat{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:8px}
.cc-s2-title{font-family:var(--font-heading);font-size:clamp(20px,2.5vw,32px);font-weight:900;color:#0d2418;line-height:1.2;margin:0 0 10px}
.cc-s2-tagline{font-size:14px;color:#666;margin:0 0 16px;line-height:1.6}
.cc-s2-bullets{list-style:none;padding:12px 16px;margin:0 0 16px;background:#f5faf6;border-radius:8px}
.cc-s2-bullets li{padding:5px 0 5px 22px;position:relative;font-size:14px;color:#333;line-height:1.5}
.cc-s2-bullets li::before{content:'\2713';position:absolute;left:0;top:5px;color:var(--color-accent);font-weight:800}
.cc-s2-price-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:14px 0}
.cc-s2-price .price{font-size:26px!important;font-weight:800!important;color:var(--color-primary)!important}
.cc-s2-price .price del{color:#aaa!important;font-size:16px!important;font-weight:400!important}
.cc-s2-price .price ins{text-decoration:none!important;color:var(--color-sale)!important}
.cc-s2-badge{background:var(--color-sale);color:#fff;font-size:11px;font-weight:800;padding:4px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.05em}
.cc-s2-cart{margin:0 0 16px}
.cc-s2-trust-strip{display:flex;flex-wrap:wrap;gap:12px;padding:14px 0;border-top:1px solid #eee;border-bottom:1px solid #eee;margin-bottom:16px}
.cc-s2-trust-strip span{display:flex;align-items:center;gap:5px;font-size:12px;color:#555;font-weight:600}
.cc-s2-trust-strip svg{width:14px;height:14px;flex-shrink:0}
.cc-s2-detail-row{display:flex;gap:8px;font-size:13px;color:#555;line-height:1.7;margin:6px 0;align-items:baseline}
.cc-s2-detail-row strong{color:#1a2d4a;font-weight:700;flex-shrink:0}
.cc-s2-accordion-area{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.06);margin-bottom:32px}
.cc-s2-acc-item{border-bottom:1px solid #eee}
.cc-s2-acc-item:last-child{border-bottom:none}
.cc-s2-acc-head{width:100%;background:none;border:none;text-align:left;padding:18px 24px;font-size:15px;font-weight:700;color:#1a2d4a;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .15s}
.cc-s2-acc-head:hover{background:#f5faf6}
.cc-s2-chevron{width:20px;height:20px;transition:transform .25s;flex-shrink:0}
.cc-s2-acc-item.open .cc-s2-chevron{transform:rotate(180deg)}
.cc-s2-acc-body{display:none;padding:0 24px 20px;font-size:14px;color:#555;line-height:1.8}
.cc-s2-acc-item.open .cc-s2-acc-body{display:block}
.cc-s2-wc-below{margin-top:32px}
@media(max-width:900px){.cc-s2-hero{grid-template-columns:1fr;gap:28px}.cc-s2-summary{position:static}.cc-s2-thumblist{flex-direction:row;width:auto;flex-wrap:wrap}.cc-s2-thumb{width:64px;height:64px}}
@media(max-width:600px){.cc-s2-wrap{width:96%}.cc-s2-summary{padding:20px}}

/* ── STYLE 3 Amazon-inspired ── */
.cc-style-3{background:#f8f8f8;padding:32px 0 80px;min-height:100vh}
.cc-s3-wrap{width:93%;max-width:1500px;margin:0 auto;padding:0 1.5%}
.cc-s3-top{display:grid;grid-template-columns:36% 37% 27%;align-items:start;background:#fff;border-radius:8px;box-shadow:0 1px 8px rgba(0,0,0,.08);overflow:hidden;margin-bottom:32px}
.cc-s3-gallery-col{padding:24px 20px;border-right:1px solid #f0f0f0}
.cc-s3-main-wrap{position:relative;border-radius:8px;overflow:hidden;background:#f8f9fa;aspect-ratio:2/3;border:1px solid #eee;margin-bottom:14px}
.cc-s3-main-wrap a{display:block;width:100%;height:100%;position:relative}
.cc-s3-main-img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .4s}
.cc-s3-main-wrap:hover .cc-s3-main-img{transform:scale(1.03)}
.cc-s3-thumbs{display:flex;gap:8px;flex-wrap:wrap}
.cc-s3-thumb{width:60px;height:60px;border-radius:4px;overflow:hidden;border:1px solid #ddd;cursor:pointer;transition:border-color .2s;background:#f8f9fa;flex-shrink:0}
.cc-s3-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.cc-s3-thumb:hover,.cc-s3-thumb.active{border-color:var(--color-primary)}
.cc-s3-info-col{padding:24px 22px;border-right:1px solid #f0f0f0}
.cc-s3-cat{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:8px}
.cc-s3-title{font-family:var(--font-heading);font-size:clamp(18px,2vw,26px);font-weight:800;color:#0f1111;line-height:1.25;margin:0 0 10px}
.cc-s3-tagline{font-size:14px;color:#555;line-height:1.6;margin:0 0 12px}
.cc-s3-divider{height:1px;background:#eee;margin:14px 0}
.cc-s3-about h3,.cc-s3-benefits-section h3{font-family:var(--font-heading);font-size:16px;font-weight:800;color:#0f1111;margin:0 0 10px}
.cc-s3-about{font-size:14px;color:#555;line-height:1.7;margin-bottom:16px}
.cc-s3-benefits-section{margin-bottom:16px}
.cc-s3-detail{font-size:13px;color:#555;line-height:1.7;margin:8px 0;display:flex;flex-direction:column;gap:4px}
.cc-s3-detail-label{font-weight:800;color:#0f1111}
.cc-s3-buy-col{padding:24px 20px;background:#f8faf9}
.cc-s3-buy-box{background:#fff;border:1px solid #d5e0d5;border-radius:8px;padding:20px}
.cc-s3-buy-price .price{font-size:24px!important;font-weight:800!important;color:#0f1111!important}
.cc-s3-buy-price .price del{color:#aaa!important;font-size:16px!important;font-weight:400!important}
.cc-s3-buy-price .price ins{text-decoration:none!important;color:var(--color-sale)!important}
.cc-s3-buy-offer{background:#fff9f0;border:1px solid #f0d080;border-radius:6px;padding:8px 12px;font-size:13px;font-weight:700;color:#b07700;margin:12px 0;display:flex;align-items:center;gap:6px}
.cc-s3-buy-offer svg{width:14px;height:14px;flex-shrink:0}
.cc-s3-buy-cart{margin:14px 0}
.cc-s3-buy-cart .single_add_to_cart_button{width:100%!important}
.cc-s3-buy-badges{border-top:1px solid #eee;margin-top:16px;padding-top:16px;display:flex;flex-direction:column;gap:10px}
.cc-s3-badge-row{display:flex;align-items:center;gap:8px;font-size:13px;color:#444}
.cc-s3-badge-row svg{width:18px;height:18px;flex-shrink:0}
.cc-s3-below{background:#fff;border-radius:8px;box-shadow:0 1px 8px rgba(0,0,0,.08);overflow:hidden;margin-bottom:32px}
.cc-s3-tab-nav{display:flex;border-bottom:2px solid #eee;overflow-x:auto}
.cc-s3-tab{background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;padding:14px 22px;font-size:14px;font-weight:700;color:#888;cursor:pointer;transition:color .2s,border-color .2s;white-space:nowrap}
.cc-s3-tab:hover{color:var(--color-primary)}
.cc-s3-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}
.cc-s3-tab-panels{padding:24px 28px}
.cc-s3-panel{display:none;font-size:15px;color:#555;line-height:1.8}
.cc-s3-panel.active{display:block}
.cc-s3-wc-below{margin-top:28px}
@media(max-width:1100px){.cc-s3-top{grid-template-columns:40% 60%}.cc-s3-buy-col{grid-column:1/-1;border-top:1px solid #f0f0f0;border-right:none;background:#fff}.cc-s3-buy-box{max-width:480px}}
@media(max-width:760px){.cc-s3-top{grid-template-columns:1fr}.cc-s3-gallery-col,.cc-s3-info-col{border-right:none;border-bottom:1px solid #f0f0f0}.cc-s3-main-wrap{max-width:75%;margin:0 auto 14px}.cc-s3-wrap{width:96%}}
@media(max-width:480px){.cc-s3-tab-panels{padding:16px}.cc-s3-main-wrap{max-width:100%}}

/* =====================================================
   CARECURE v10 — DEFINITIVE GRID FIX
   Fixes: 2-then-3 row pattern caused by WooCommerce
   clearfix pseudo-elements on ul.products + li.first
===================================================== */
ul.products::before, ul.products::after {
  content:none!important; display:none!important; clear:none!important; float:none!important;
}
ul.products li.product::before, ul.products li.product::after,
ul.products li.product.first::before, ul.products li.product.first::after,
ul.products li.product.last::before, ul.products li.product.last::after {
  content:none!important; display:none!important; clear:none!important;
  float:none!important; width:0!important; height:0!important;
}
ul.products,ul.products.columns-1,ul.products.columns-2,
ul.products.columns-3,ul.products.columns-4,
ul.products.columns-5,ul.products.columns-6 {
  display:grid!important;
  grid-template-columns:repeat(3,1fr)!important;
  grid-auto-flow:row!important;
  gap:28px!important;
  list-style:none!important;
  padding:0!important;
  margin:0 0 40px!important;
  float:none!important;
  clear:none!important;
  width:100%!important;
  overflow:visible!important;
}
ul.products li.product, ul.products li.product.first, ul.products li.product.last {
  display:flex!important; flex-direction:column!important;
  float:none!important; clear:none!important; width:auto!important;
  margin:0!important; padding:0!important; position:relative!important;
  background:#fff; border-radius:10px; overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,.06); transition:box-shadow .25s,transform .25s;
}
ul.products li.product:hover { box-shadow:0 8px 32px rgba(0,0,0,.12); transform:translateY(-3px); }
ul.products li.product a img,
ul.products li.product .attachment-woocommerce_thumbnail,
ul.products li.product .wp-post-image {
  display:block!important; width:100%!important; height:auto!important;
  aspect-ratio:2/3!important; object-fit:contain!important; object-position:center!important;
  background:var(--cc-light,#f4f8f0)!important; padding:14px!important; box-sizing:border-box!important;
}
@media(max-width:900px){
  ul.products,ul.products[class*="columns-"] { grid-template-columns:repeat(2,1fr)!important; }
}
@media(max-width:480px){
  ul.products,ul.products[class*="columns-"] { grid-template-columns:1fr!important; }
}

/* =====================================================
   BRAND COLOR VARIABLES — logo palette defaults
   Runtime values injected by carecure_inject_brand_colors()
===================================================== */
:root {
  --cc-green: #8dc63f;
  --cc-red:   #c62a2a;
  --cc-gold:  #f5a623;
  --cc-dark:  #1c2e26;
  --cc-light: #f4f8f0;
}
.single_add_to_cart_button,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit { background-color:var(--cc-green)!important; border-color:var(--cc-green)!important; color:#fff!important; }
.single_add_to_cart_button:hover, .woocommerce a.button:hover,
.woocommerce button.button:hover { background-color:var(--cc-dark)!important; }
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price, .woocommerce div.product span.price { color:var(--cc-gold)!important; }
.woocommerce ul.products li.product .onsale, .woocommerce span.onsale { background:var(--cc-red)!important; }
