/**
 * WooCommerce Styles - Sync Recommerce
 * Consolidated styles using design-tokens.css
 *
 * @package Sync_Recommerce
 * @version 2.0.0
 */

/* ============================================
   SHOP PAGE HEADER
   ============================================ */

/* Hide on shop archive (title shown differently) */
.post-type-archive-product .woocommerce-products-header,
.tax-product_cat .woocommerce-products-header {
  display: none;
}

/* Show on cart, checkout, account pages */
.woocommerce-cart .woocommerce-products-header,
.woocommerce-checkout .woocommerce-products-header,
.woocommerce-account .woocommerce-products-header {
  background: var(--gradient-primary);
  padding: var(--space-10) 0;
  margin-bottom: var(--space-8);
}

.woocommerce-cart .woocommerce-products-header__title,
.woocommerce-checkout .woocommerce-products-header__title,
.woocommerce-account .woocommerce-products-header__title {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--color-white);
  margin: 0;
}

/* ============================================
   SHOP-SPECIFIC SITE HEADER
   ============================================ */

/* Search bar styling */
.shop-header .header-search {
  flex: 1;
  max-width: 400px;
  margin: 0;
}

.shop-header .header-search form {
  position: relative;
  display: flex;
  align-items: center;
}

.shop-header .header-search .search-icon-inline {
  position: absolute;
  left: 12px;
  color: var(--color-gray-500);
  font-size: var(--text-sm);
  pointer-events: none;
  z-index: 1;
}

.shop-header .header-search .search-field {
  width: 100%;
  padding: var(--space-2) var(--space-4) var(--space-2) var(--space-10);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-full);
  font-size: var(--text-sm);
  font-family: var(--font-primary);
  color: var(--color-secondary);
  background: var(--bg-secondary);
  transition: all var(--transition-fast);
  height: 40px;
}

.shop-header .header-search .search-field:focus {
  outline: none;
  border-color: var(--color-primary);
  background: var(--bg-primary);
  box-shadow: 0 0 0 3px rgba(0, 153, 204, 0.1);
}

.shop-header .header-search .search-submit {
  position: absolute;
  right: var(--space-2);
  top: 50%;
  transform: translateY(-50%);
  background: var(--gradient-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--border-radius-full);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.shop-header .header-search .search-submit:hover {
  transform: translateY(-50%) scale(1.05);
  box-shadow: var(--shadow-brand);
}

.shop-header .header-search .search-submit i {
  font-size: var(--text-base);
}

/* Hide search on mobile initially */
.shop-header .header-search-mobile {
  display: none;
}

/* Hide "Browse Inventory" button on shop page */
.shop-header .header-btn-shop {
  display: none;
}

/* Adjust navigation for shop header */
.shop-header .main-navigation {
  margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
  .shop-header .header-search {
    max-width: 400px;
    margin: 0 var(--space-4);
  }
}

@media (max-width: 768px) {
  /* Hide desktop search */
  .shop-header .header-search {
    display: none;
  }

  /* Show mobile search */
  .shop-header .header-search-mobile {
    display: block;
    padding: var(--space-3) 0;
    border-top: 1px solid var(--border-color);
  }

  .shop-header .header-search-mobile form {
    position: relative;
    display: flex;
    align-items: center;
  }

  .shop-header .header-search-mobile .search-field {
    width: 100%;
    padding: var(--space-3) var(--space-12) var(--space-3) var(--space-4);
    border: 2px solid var(--border-color);
    border-radius: var(--border-radius-full);
    font-size: var(--text-sm);
    font-family: var(--font-primary);
    color: var(--color-secondary);
    background: var(--bg-secondary);
  }

  .shop-header .header-search-mobile .search-field:focus {
    outline: none;
    border-color: var(--color-primary);
    background: var(--bg-primary);
  }

  .shop-header .header-search-mobile .search-submit {
    position: absolute;
    right: var(--space-2);
    background: var(--gradient-primary);
    color: var(--color-white);
    border: none;
    border-radius: var(--border-radius-full);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
  }
}

/* ============================================
   SHOP LAYOUT WITH SIDEBAR
   ============================================ */

/* Main wrapper for shop page content */
.woocommerce-page-wrapper {
  padding-bottom: var(--space-12);
}

/* Full-width container for shop with padding */
.woocommerce-page-wrapper .container-full {
  max-width: 100%;
  padding: 0 var(--space-8);
  margin: 0 auto;
}

@media (max-width: 768px) {
  .woocommerce-page-wrapper .container-full {
    padding: 0 var(--space-4);
  }
}

/* Layout principal con sidebar */
.shop-layout-with-sidebar {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-8);
  margin-top: var(--space-6);
}

/* Sidebar */
.shop-sidebar {
  position: sticky;
  top: 80px;
  align-self: start;
  height: fit-content;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
}

.sidebar-inner {
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-lg);
  padding: var(--space-6);
}

/* Widgets de filtros */
.shop-sidebar .widget {
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--border-color);
}

.shop-sidebar .widget:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.shop-sidebar .widget-title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin-bottom: var(--space-4);
  line-height: 1.3;
}

/* Hide duplicate WooCommerce widget titles */
.shop-sidebar .widget .widgettitle {
  display: none;
}

/* Widget inner container spacing */
.shop-sidebar .widget .woocommerce.widget_price_filter,
.shop-sidebar .widget .woocommerce.widget_product_categories,
.shop-sidebar .widget .woocommerce.widget_layered_nav {
  margin-top: 0;
}

/* Empty widget message */
.shop-sidebar .widget-filter:empty::after {
  content: "No hay filtros disponibles";
  display: block;
  padding: var(--space-3);
  color: var(--color-gray-500);
  font-size: var(--text-sm);
  font-style: italic;
  text-align: center;
  background: var(--bg-secondary);
  border-radius: var(--border-radius-md);
}

/* Estilo para listas de categorías y atributos */
.shop-sidebar .widget ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.shop-sidebar .widget ul li {
  margin-bottom: var(--space-2);
  padding-left: 0;
}

.shop-sidebar .widget ul li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  color: var(--color-gray-700);
  text-decoration: none;
  border-radius: var(--border-radius-md);
  transition: all var(--transition-fast);
  font-size: var(--text-sm);
  border: 1px solid transparent;
  font-weight: var(--font-medium);
}

.shop-sidebar .widget ul li a:hover {
  background: var(--bg-secondary);
  color: var(--color-primary);
  border-color: var(--border-color);
  transform: translateX(4px);
}

.shop-sidebar .widget ul li.current-cat > a,
.shop-sidebar .widget ul li.chosen > a {
  background: rgba(0, 153, 204, 0.08);
  color: var(--color-primary);
  font-weight: var(--font-bold);
  border-color: var(--color-primary);
}

/* Contador de productos */
.shop-sidebar .widget ul li .count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 20px;
  padding: 0 var(--space-2);
  background: var(--bg-secondary);
  color: var(--color-gray-600);
  border-radius: var(--border-radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  margin-left: var(--space-2);
}

/* Slider de precio */
.shop-sidebar .price_slider_wrapper {
  padding: var(--space-2) 0 var(--space-4) 0;
}

.shop-sidebar .price_slider {
  margin-bottom: var(--space-4);
  height: 6px;
  background: var(--bg-secondary);
  border-radius: var(--border-radius-full);
  border: none;
}

.shop-sidebar .price_slider .ui-slider-range {
  background: var(--gradient-primary);
  border-radius: var(--border-radius-full);
}

.shop-sidebar .price_slider .ui-slider-handle {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--color-white);
  border: 3px solid var(--color-primary);
  cursor: pointer;
  top: -6px;
  outline: none;
  transition: all var(--transition-fast);
}

.shop-sidebar .price_slider .ui-slider-handle:hover,
.shop-sidebar .price_slider .ui-slider-handle:focus {
  transform: scale(1.2);
  box-shadow: 0 0 0 4px rgba(0, 153, 204, 0.1);
}

.shop-sidebar .price_slider_amount {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--space-4);
  gap: var(--space-3);
}

.shop-sidebar .price_slider_amount .price_label {
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  flex: 1;
}

.shop-sidebar .price_slider_amount .price_label .from,
.shop-sidebar .price_slider_amount .price_label .to {
  color: var(--color-primary);
  font-weight: var(--font-extrabold);
}

.shop-sidebar .price_slider_amount .button {
  background: var(--gradient-primary);
  color: var(--color-white);
  border: none;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--border-radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  cursor: pointer;
  transition: all var(--transition-base);
  white-space: nowrap;
  font-family: var(--font-heading);
  letter-spacing: 0.02em;
}

.shop-sidebar .price_slider_amount .button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-brand);
}

/* Botón para limpiar filtros */
.shop-sidebar .woocommerce-widget-layered-nav-list__item--chosen a::before {
  content: "✕ ";
  margin-right: var(--space-1);
  font-weight: bold;
}

/* Área principal de contenido */
.shop-main-content {
  min-width: 0;
}

/* Search Results Header */
.search-results-header {
  background: var(--bg-secondary);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--border-radius-md);
  padding: var(--space-4) var(--space-6);
  margin-bottom: var(--space-6);
}

.search-results-title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  margin: 0;
  line-height: 1.4;
}

.search-results-title .search-term {
  color: var(--color-primary);
  font-weight: var(--font-bold);
}

/* Responsive - Tablet */
@media (max-width: 1024px) {
  .shop-layout-with-sidebar {
    grid-template-columns: 240px 1fr;
    gap: var(--space-6);
  }

  .shop-sidebar {
    top: 70px;
  }

  /* En tablets, usar 3 columnas de productos */
  .shop-main-content .woocommerce ul.products,
  .shop-main-content ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* Responsive - Mobile */
@media (max-width: 768px) {
  .shop-layout-with-sidebar {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .shop-sidebar {
    position: relative;
    top: 0;
    max-height: none;
    margin-bottom: var(--space-6);
  }

  .sidebar-inner {
    padding: var(--space-4);
  }

  .shop-sidebar .widget {
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-4);
  }

  .shop-sidebar .widget-title {
    font-size: var(--text-base);
    margin-bottom: var(--space-3);
  }
}

/* Toggle para sidebar en móvil (opcional para futuro) */
.sidebar-toggle {
  display: none;
  margin-bottom: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--border-radius-md);
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  cursor: pointer;
  width: 100%;
  text-align: center;
}

@media (max-width: 768px) {
  .sidebar-toggle {
    display: block;
  }

  .shop-sidebar.collapsed {
    display: none;
  }
}

/* ============================================
   PRODUCT LOOP (Shop Archive & Front Page)
   ============================================ */

/* Base grid - applies to ALL product loops */
.woocommerce ul.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  grid-auto-flow: row dense !important;
  gap: var(--space-6) !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0 !important;
}

/* Ajuste del grid cuando hay sidebar (en shop page) */
.shop-main-content .woocommerce ul.products,
.shop-main-content ul.products {
  grid-template-columns: repeat(4, 1fr) !important;
}

/* Reset font size for products */
.woocommerce ul.products li.product,
ul.products li.product {
  font-size: 1rem !important;
}

/* Hide empty list items and whitespace nodes */
.woocommerce ul.products li:empty,
ul.products li:empty,
.woocommerce ul.products li:not(.product),
ul.products li:not(.product) {
  display: none !important;
}

/* Remove any pseudo elements or results element */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
ul.products::before,
ul.products::after {
  display: none !important;
  content: none !important;
}

/* Hide WooCommerce result count if it's inside products list */
.woocommerce ul.products .woocommerce-result-count,
ul.products .woocommerce-result-count {
  display: none !important;
}

/* Featured Products - 4 columns on front page */
.products-featured .woocommerce ul.products,
.products-featured ul.products {
  grid-template-columns: repeat(4, 1fr) !important;
}

/* Tablet - 2 columns for all */
@media (max-width: 1024px) {
  .woocommerce ul.products,
  ul.products,
  .products-featured .woocommerce ul.products,
  .products-featured ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* Mobile - 1 column for all */
@media (max-width: 640px) {
  .woocommerce ul.products,
  ul.products,
  .products-featured .woocommerce ul.products,
  .products-featured ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* Product link wrapper */
.woocommerce ul.products li.product a,
ul.products li.product a {
  text-decoration: none !important;
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
ul.products li.product a.woocommerce-LoopProduct-link {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

.woocommerce ul.products li.product,
ul.products li.product {
  background: var(--bg-primary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius-lg) !important;
  overflow: hidden !important;
  transition: all var(--transition-base) !important;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
}

.woocommerce ul.products li.product:hover,
ul.products li.product:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-xl) !important;
  border-color: var(--color-primary) !important;
}

.woocommerce ul.products li.product img,
ul.products li.product img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  transition: transform var(--transition-base) !important;
  display: block !important;
}

.woocommerce ul.products li.product:hover img,
ul.products li.product:hover img {
  transform: scale(1.05) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
ul.products li.product h2 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-secondary) !important;
  padding: var(--space-4) !important;
  margin: 0 !important;
  line-height: var(--leading-tight) !important;
}

.woocommerce ul.products li.product .price {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
  padding: 0 var(--space-4) var(--space-3);
  display: block;
}

.woocommerce ul.products li.product .price del {
  color: var(--color-gray-500);
  font-size: var(--text-base);
  font-weight: var(--font-normal);
  margin-right: var(--space-2);
}

.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  color: var(--color-primary);
}

.woocommerce ul.products li.product .button {
  width: calc(100% - var(--space-8));
  margin: 0 var(--space-4) var(--space-4);
  background: var(--gradient-primary);
  color: var(--color-white);
  border: none;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--border-radius-md);
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  text-align: center;
  transition: all var(--transition-base);
  cursor: pointer;
}

.woocommerce ul.products li.product .button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-brand);
}

/* Hide "View cart" link injected into product cards after AJAX add-to-cart */
.woocommerce ul.products li.product .added_to_cart {
  display: none;
}

/* Product Badges - Hidden on shop archive */
.woocommerce ul.products li.product .onsale,
ul.products li.product .onsale {
  display: none !important;
}

/* Manifested Badge (old class) - Hidden on shop archive */
.woocommerce ul.products li.product .sync-manifested-badge,
ul.products li.product .sync-manifested-badge {
  display: none !important;
}

/* Manifested Tag - Subtle indicator on product cards */
.woocommerce ul.products li.product .sync-manifested-tag,
ul.products li.product .sync-manifested-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  color: var(--color-success);
  padding: 0 var(--space-4);
  margin-bottom: var(--space-1, 4px);
  opacity: 0.85;
}

.sync-manifested-tag i {
  font-size: 12px;
}

.sync-manifested-tag__count {
  color: var(--color-gray-500);
  font-weight: var(--font-normal);
  margin-left: 2px;
}

/* ============================================
   SINGLE PRODUCT - Professional Design
   ============================================ */

.single-product div.product {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-10);
  margin-bottom: var(--space-12);
  position: relative;
  align-items: start;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}

/* Product Gallery - Clean Professional */
.single-product div.product .woocommerce-product-gallery {
  flex: 0 0 500px;
  max-width: 500px;
  position: sticky;
  top: 0;
  height: fit-content;
  background: var(--bg-secondary);
  padding: 0;
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.single-product div.product .woocommerce-product-gallery img {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  display: block;
  background: var(--bg-secondary);
  padding: var(--space-8);
}

/* Product Summary */
.single-product div.product .summary {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

/* Product Title */
.single-product div.product .product_title {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin: 0 0 var(--space-3) 0;
  line-height: var(--leading-snug);
  letter-spacing: -0.01em;
}

/* SKU and Stock Meta Row */
.single-product div.product .product_meta {
  padding: 0 0 var(--space-5) 0;
  border-bottom: 0;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.single-product div.product .product_meta .sku_wrapper {
  display: flex;
  align-items: center;
  gap: 0;
  color: var(--color-gray-600);
  font-size: var(--text-sm);
  border: none;
  padding: 0;
}

.single-product div.product .product_meta .sku_wrapper::before {
  display: none;
}

.single-product div.product .product_meta .sku {
  font-weight: var(--font-normal);
}

/* Separator between SKU and Stock */
.single-product div.product .product_meta .sku_wrapper::after {
  content: "|";
  margin: 0 var(--space-3);
  color: var(--color-gray-400);
}

/* Stock Status Badge */
.single-product div.product p.stock {
  display: inline-flex !important;
  align-items: center;
  gap: var(--space-2);
  padding: 0 !important;
  background: transparent !important;
  color: #28a745 !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-medium) !important;
  margin: 0 !important;
  border: none !important;
  width: fit-content !important;
  border-radius: 0 !important;
}

.single-product div.product p.stock::before {
  content: "●";
  font-size: 8px;
  display: inline-block;
}

.single-product div.product p.stock.out-of-stock {
  color: #dc3545 !important;
}

.single-product div.product p.stock.out-of-stock::before {
  content: "✕";
  font-size: 10px;
}

/* Price Section with Border */
.product-price-section {
  padding: var(--space-5) 0;
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
  width: 100%;
}

/* Price - Clean and Clear */
.single-product div.product p.price {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--font-extrabold);
  color: var(--color-secondary);
  margin: 0 0 var(--space-2) 0;
  padding: 0;
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  line-height: 1;
}

.single-product div.product p.price del {
  color: var(--color-gray-500);
  font-size: var(--text-base);
  font-weight: var(--font-normal);
  order: 2;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.single-product div.product p.price del::before {
  content: "Retail Value:";
  color: var(--color-gray-500);
  font-weight: var(--font-normal);
  font-size: var(--text-sm);
}

/* Savings Badge */
.product-savings {
  display: inline-block;
  padding: var(--space-2) var(--space-3);
  background: #E8F5E9;
  color: var(--color-success);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  border-radius: var(--border-radius-sm);
  margin-top: var(--space-2);
}

/* Specifications Section */
.product-specifications-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.product-specifications-title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  margin: 0;
}

/* Product Specifications - List Style */
.single-product div.product .woocommerce-product-details__short-description {
  margin: 0;
  padding: 0;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.single-product div.product .woocommerce-product-details__short-description ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.single-product div.product .woocommerce-product-details__short-description li {
  padding: var(--space-4) var(--space-5);
  margin-bottom: 0;
  color: var(--color-secondary);
  font-size: var(--text-sm);
  line-height: 1.5;
  border-bottom: 1px solid var(--border-color);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-6);
  background: var(--bg-primary);
}

.single-product div.product .woocommerce-product-details__short-description li:last-child {
  border-bottom: none;
}

.single-product div.product .woocommerce-product-details__short-description li::before {
  content: "•";
  color: var(--color-gray-600);
  font-weight: var(--font-normal);
  font-size: var(--text-base);
  flex-shrink: 0;
  margin-right: var(--space-1);
}

/* Format spec items as label: value */
.single-product div.product .woocommerce-product-details__short-description li strong {
  color: var(--color-gray-600);
  font-weight: var(--font-normal);
  flex-shrink: 0;
}

.single-product div.product .woocommerce-product-details__short-description li em {
  color: var(--color-secondary);
  font-weight: var(--font-medium);
  font-style: normal;
  text-align: right;
}

/* Cart Form - Professional Inline */
.single-product div.product form.cart {
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
  display: flex;
  gap: var(--space-4);
  align-items: flex-end;
}

.single-product div.product form.cart .quantity {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.single-product div.product form.cart .quantity label {
  font-weight: var(--font-semibold);
  color: var(--color-gray-600);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.single-product div.product form.cart input[type="number"] {
  width: 100px;
  height: 52px;
  padding: var(--space-3) var(--space-4);
  border: 2px solid var(--border-color);
  border-radius: var(--border-radius-sm);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  text-align: center;
  color: var(--color-secondary);
  background: var(--color-white);
  font-family: var(--font-heading);
  transition: all var(--transition-fast);
}

.single-product div.product form.cart input[type="number"]:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(0, 153, 204, 0.1);
}

/* Add to Cart Button - Professional B2B Style */
.single-product div.product .single_add_to_cart_button {
  flex: 1;
  height: 52px;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  padding: 0 var(--space-8);
  border-radius: var(--border-radius-sm);
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  transition: all var(--transition-fast);
  cursor: pointer;
  text-align: center;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
}

.single-product div.product .single_add_to_cart_button:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 153, 204, 0.3);
}

.single-product div.product .single_add_to_cart_button:active {
  background: var(--color-secondary);
  transform: translateY(0);
}

/* Add cart icon to button */
.single-product div.product .single_add_to_cart_button::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"%3E%3Ccircle cx="9" cy="21" r="1"/%3E%3Ccircle cx="20" cy="21" r="1"/%3E%3Cpath d="M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6"/%3E%3C/svg%3E');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* Product Meta - Categories and Tags at Bottom */
.product-meta-wrapper {
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-color);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.single-product div.product .product_meta.product-categories {
  padding: 0;
  background: transparent;
  border: none;
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.single-product div.product .product_meta.product-categories > span {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-normal);
  padding: 0;
  border: none;
}

.single-product div.product .product_meta.product-categories > span::before {
  display: none;
}

.single-product div.product .product_meta.product-categories .posted_in,
.single-product div.product .product_meta.product-categories .tagged_as {
  color: var(--color-gray-600);
  font-weight: var(--font-normal);
  margin-right: var(--space-1);
}

.single-product div.product .product_meta.product-categories a {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: var(--font-normal);
  transition: color var(--transition-fast);
}

.single-product div.product .product_meta.product-categories a:hover {
  text-decoration: underline;
}

/* Hide SKU from bottom meta if shown at top */
.single-product div.product .product_meta.product-categories .sku_wrapper {
  display: none;
}

/* Product Tabs - Clean Professional */
.woocommerce-tabs {
  flex: 1 1 100%;
  width: 100%;
  margin-top: 0;
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
}

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

.woocommerce-tabs ul.tabs li {
  margin: 0;
}

.woocommerce-tabs ul.tabs li a {
  display: block;
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  color: var(--color-gray-700);
  text-decoration: none;
  background: transparent;
  transition: all var(--transition-fast);
  border-bottom: 3px solid transparent;
}

.woocommerce-tabs ul.tabs li.active a {
  color: var(--color-primary);
  background: var(--bg-primary);
  border-bottom-color: var(--color-primary);
}

.woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-primary);
  background: var(--bg-primary);
}

/* Tab Panels */
.woocommerce-tabs .panel {
  padding: var(--space-8);
  background: var(--bg-primary);
}

.woocommerce-tabs .panel h2 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin: 0 0 var(--space-6) 0;
  padding-bottom: var(--space-4);
  border-bottom: 2px solid var(--border-color);
}

.woocommerce-tabs .panel ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.woocommerce-tabs .panel ul li {
  padding-left: var(--space-6);
  margin-bottom: var(--space-4);
  position: relative;
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
}

.woocommerce-tabs .panel ul li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: var(--font-bold);
}

/* Additional Information Table */
.woocommerce-tabs .woocommerce-product-attributes {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-6) 0 0 0;
}

.woocommerce-tabs .woocommerce-product-attributes tr {
  border-bottom: 1px solid var(--border-color);
}

.woocommerce-tabs .woocommerce-product-attributes tr:last-child {
  border-bottom: none;
}

.woocommerce-tabs .woocommerce-product-attributes th {
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  text-align: left;
  padding: var(--space-4);
  background: var(--bg-secondary);
  width: 30%;
  font-family: var(--font-heading);
}

.woocommerce-tabs .woocommerce-product-attributes td {
  padding: var(--space-4);
  color: var(--color-gray-700);
}

/* ============================================
   CART PAGE
   ============================================ */

.woocommerce-cart table.cart {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-8);
}

.woocommerce-cart table.cart th {
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  text-align: left;
  padding: var(--space-4);
  border-bottom: 2px solid var(--border-color);
  color: var(--color-secondary);
}

.woocommerce-cart table.cart td {
  padding: var(--space-4);
  border-bottom: 1px solid var(--border-color);
  vertical-align: middle;
}

.woocommerce-cart table.cart img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: var(--border-radius-md);
  border: 1px solid var(--border-color);
}

.woocommerce-cart table.cart .product-name a {
  color: var(--color-secondary);
  font-weight: var(--font-semibold);
  text-decoration: none;
}

.woocommerce-cart table.cart .product-name a:hover {
  color: var(--color-primary);
}

.woocommerce-cart table.cart .product-price,
.woocommerce-cart table.cart .product-subtotal {
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}

.woocommerce-cart table.cart input[type="number"] {
  width: 80px;
  padding: var(--space-2);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  text-align: center;
}

.woocommerce-cart table.cart .remove {
  color: var(--color-danger);
  font-size: var(--text-xl);
  text-decoration: none;
}

.woocommerce-cart table.cart .remove:hover {
  color: var(--color-secondary-dark);
}

.woocommerce-cart .cart-collaterals {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  margin-top: var(--space-8);
}

.woocommerce-cart .cart_totals {
  background: var(--bg-secondary);
  padding: var(--space-6);
  border-radius: var(--border-radius-lg);
}

.woocommerce-cart .cart_totals h2 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin-bottom: var(--space-4);
}

.woocommerce-cart .cart_totals table {
  width: 100%;
  margin-bottom: var(--space-6);
}

.woocommerce-cart .cart_totals th,
.woocommerce-cart .cart_totals td {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-color);
}

.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
  border-top: 2px solid var(--border-color);
  padding-top: var(--space-4);
}

.woocommerce-cart .cart_totals .checkout-button {
  width: 100%;
  background: var(--gradient-primary);
  color: var(--color-white);
  padding: var(--space-4);
  border: none;
  border-radius: var(--border-radius-md);
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  text-align: center;
  transition: all var(--transition-base);
  cursor: pointer;
  display: block;
  text-decoration: none;
}

.woocommerce-cart .cart_totals .checkout-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-xl);
}

/* ============================================
   CHECKOUT PAGE
   ============================================ */

.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin-bottom: var(--space-6);
}

.woocommerce-checkout .form-row {
  margin-bottom: var(--space-4);
}

.woocommerce-checkout .form-row label {
  display: block;
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  margin-bottom: var(--space-2);
}

.woocommerce-checkout .form-row input[type="text"],
.woocommerce-checkout .form-row input[type="email"],
.woocommerce-checkout .form-row input[type="tel"],
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  width: 100%;
  padding: var(--space-3);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  font-size: var(--text-base);
  transition: border-color var(--transition-fast);
}

.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
  outline: none;
  border-color: var(--color-primary);
}

.woocommerce-checkout #order_review_heading {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin-bottom: var(--space-6);
}

.woocommerce-checkout #order_review {
  background: var(--bg-secondary);
  padding: var(--space-6);
  border-radius: var(--border-radius-lg);
}

.woocommerce-checkout #place_order {
  width: 100%;
  background: var(--gradient-primary);
  color: var(--color-white);
  padding: var(--space-4);
  border: none;
  border-radius: var(--border-radius-md);
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  text-align: center;
  transition: all var(--transition-base);
  cursor: pointer;
  margin-top: var(--space-6);
}

.woocommerce-checkout #place_order:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-xl);
}

/* ============================================
   BLOCK CHECKOUT - WooCommerce Gutenberg Blocks
   ============================================ */

/* Page wrapper */
.woocommerce-checkout .woocommerce-page-wrapper {
  padding-bottom: var(--space-12);
}

.woocommerce-checkout .woocommerce-page-wrapper > .container {
  max-width: var(--container-xl);
}

/* Main layout - don't override gap, WC calculates sidebar fit based on it */
.woocommerce-checkout .wc-block-checkout .wc-block-components-sidebar-layout {
  align-items: flex-start;
}

/* --- Step sections (Contact, Billing, Payment) --- */
.woocommerce-checkout .wc-block-components-checkout-step__title {
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  font-size: var(--text-xl);
  color: var(--color-secondary);
}

.woocommerce-checkout .wc-block-components-checkout-step__description {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

/* --- Form inputs --- */
.woocommerce-checkout .wc-block-components-text-input input,
.woocommerce-checkout .wc-block-components-text-input textarea {
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  font-family: var(--font-primary);
  font-size: var(--text-base);
  color: var(--color-secondary);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.woocommerce-checkout .wc-block-components-text-input input:focus,
.woocommerce-checkout .wc-block-components-text-input textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(1, 94, 124, 0.1);
}

.woocommerce-checkout .wc-block-components-text-input label {
  font-family: var(--font-primary);
  color: var(--color-gray-500);
}

/* Select dropdowns */
.woocommerce-checkout .wc-blocks-components-select__select {
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  font-family: var(--font-primary);
  font-size: var(--text-base);
  color: var(--color-secondary);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.woocommerce-checkout .wc-blocks-components-select__select:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(1, 94, 124, 0.1);
  outline: none;
}

.woocommerce-checkout .wc-blocks-components-select__label {
  font-family: var(--font-primary);
  color: var(--color-gray-500);
}

/* --- Order summary sidebar --- */
.woocommerce-checkout .wc-block-checkout__sidebar {
  background: var(--bg-secondary);
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--border-color);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  box-sizing: border-box;
}

/* Remove inner border that doubles with the card border */
.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block {
  border: none;
}

/* Order summary title */
.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-panel__button {
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  font-size: var(--text-lg);
  color: var(--color-secondary);
}

/* Product items in order summary */
.woocommerce-checkout .wc-block-components-order-summary-item__description .wc-block-components-product-name {
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  font-size: var(--text-sm);
}

.woocommerce-checkout .wc-block-components-order-summary-item__total-price {
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}

.woocommerce-checkout .wc-block-components-order-summary-item__individual-price {
  color: var(--color-gray-500);
}

/* Totals rows */
.woocommerce-checkout .wc-block-components-totals-item__label {
  font-family: var(--font-primary);
  color: var(--color-secondary);
}

.woocommerce-checkout .wc-block-components-totals-item__value {
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
}

/* Footer total */
.woocommerce-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
}

.woocommerce-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-footer-item-tax-value {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}

/* Coupon link */
.woocommerce-checkout .wc-block-components-totals-coupon .wc-block-components-panel__button {
  font-size: var(--text-sm);
  color: var(--color-primary);
  font-weight: var(--font-medium);
}

/* --- Place Order button --- */
.woocommerce-checkout .wc-block-components-checkout-place-order-button {
  background: var(--gradient-primary) !important;
  color: var(--color-white) !important;
  padding: var(--space-4) var(--space-8) !important;
  border: none !important;
  border-radius: var(--border-radius-md) !important;
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-bold) !important;
  cursor: pointer;
  transition: all var(--transition-base) !important;
  box-shadow: var(--shadow-md);
  min-height: 52px;
}

.woocommerce-checkout .wc-block-components-checkout-place-order-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-brand) !important;
}

/* --- Return to Cart link --- */
.woocommerce-checkout .wc-block-components-checkout-return-to-cart-button {
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-gray-500);
  text-decoration: none;
  transition: color var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.woocommerce-checkout .wc-block-components-checkout-return-to-cart-button:hover {
  color: var(--color-primary);
}

/* --- Error/Notice banners --- */
.woocommerce-checkout .wc-block-components-notice-banner.is-error {
  background: #FEF2F2;
  border: 1px solid #FECACA;
  border-radius: var(--border-radius-md);
  color: #991B1B;
  font-family: var(--font-primary);
  font-size: var(--text-sm);
}

.woocommerce-checkout .wc-block-components-notice-banner.is-error .wc-block-components-notice-banner__content {
  color: #991B1B;
}

/* --- Terms and conditions text --- */
.woocommerce-checkout .wc-block-checkout__actions .wc-block-components-checkout-policies {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

.woocommerce-checkout .wc-block-checkout__actions .wc-block-components-checkout-policies a {
  color: var(--color-primary);
  text-decoration: none;
}

.woocommerce-checkout .wc-block-checkout__actions .wc-block-components-checkout-policies a:hover {
  text-decoration: underline;
}

/* --- Checkbox styling --- */
.woocommerce-checkout .wc-block-components-checkbox .wc-block-components-checkbox__input[type="checkbox"]:checked {
  accent-color: var(--color-primary);
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .woocommerce-checkout .wc-block-checkout .wc-block-components-sidebar-layout {
    flex-direction: column;
  }

  .woocommerce-checkout .wc-block-checkout__sidebar {
    width: 100%;
    position: static;
  }

  .woocommerce-checkout .wc-block-components-checkout-place-order-button {
    width: 100% !important;
  }
}

/* ============================================
   BREADCRUMBS & NAVIGATION
   ============================================ */

.woocommerce-breadcrumb {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-color);
}

.woocommerce-breadcrumb a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.woocommerce-breadcrumb a:hover {
  text-decoration: underline;
}

/* Toolbar - Result count + Ordering */
.woocommerce-notices-wrapper + .container > p:first-of-type,
.woocommerce-result-count {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  font-weight: var(--font-medium);
}

.woocommerce-ordering {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.woocommerce-ordering .orderby {
  min-width: 200px;
  padding: var(--space-3) var(--space-4);
  padding-right: var(--space-10);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  font-size: var(--text-sm);
  font-family: var(--font-primary);
  color: var(--color-secondary);
  background: var(--bg-primary);
  background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"%3E%3Cpath fill="%230099cc" d="M6 9L1 4h10z"/%3E%3C/svg%3E');
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  background-size: 12px;
  cursor: pointer;
  transition: all var(--transition-fast);
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.woocommerce-ordering .orderby:hover {
  border-color: var(--color-primary);
  background-color: var(--bg-secondary);
}

.woocommerce-ordering .orderby:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(0, 153, 204, 0.1);
}

/* Toolbar layout - appears above products */
.shop-main-content > .woocommerce-notices-wrapper + p.woocommerce-result-count,
.shop-main-content > .woocommerce-result-count {
  margin-bottom: var(--space-6);
}

@media (max-width: 640px) {
  .woocommerce-ordering {
    width: 100%;
  }

  .woocommerce-ordering .orderby {
    width: 100%;
    min-width: 0;
  }
}

/* ============================================
   MESSAGES & NOTICES
   ============================================ */

/* Toast notifications - floating */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  position: fixed !important;
  top: var(--space-6);
  right: var(--space-6);
  z-index: var(--z-tooltip);
  max-width: 380px;
  width: auto;
  padding: var(--space-4) var(--space-5) !important;
  margin: 0 !important;
  border-radius: var(--border-radius-md) !important;
  border: none !important;
  border-left: 4px solid !important;
  box-shadow: var(--shadow-xl);
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
  animation: toast-slide-in 0.3s ease-out;
}

/* Kill WooCommerce default ::before icon */
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
  display: none !important;
  content: none !important;
}

.woocommerce-message.toast-hiding,
.woocommerce-info.toast-hiding,
.woocommerce-error.toast-hiding {
  animation: toast-slide-out 0.3s ease-in forwards;
}

@keyframes toast-slide-in {
  from { opacity: 0; transform: translateX(40px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes toast-slide-out {
  from { opacity: 1; transform: translateX(0); }
  to { opacity: 0; transform: translateX(40px); }
}

.woocommerce-message {
  background: var(--color-white);
  border-left-color: var(--color-success) !important;
  color: var(--color-secondary);
}

.woocommerce-info {
  background: var(--color-white);
  border-left-color: var(--color-info) !important;
  color: var(--color-secondary);
}

.woocommerce-error {
  background: var(--color-white);
  border-left-color: var(--color-danger) !important;
  color: var(--color-secondary);
}

/* "View cart" link as subtle text link */
.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
  display: inline;
  margin: 0;
  padding: 0;
  background: none !important;
  border: none;
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  text-decoration: underline;
  text-underline-offset: 2px;
  white-space: nowrap;
  cursor: pointer;
  transition: color var(--transition-fast);
}

.woocommerce-message .button:hover,
.woocommerce-info .button:hover,
.woocommerce-error .button:hover {
  color: var(--color-primary-dark);
}

/* ============================================
   RESPONSIVE
   ============================================ */

/* Reviews Section */
.woocommerce-tabs #reviews .woocommerce-noreviews {
  padding: var(--space-8);
  text-align: center;
  color: var(--color-gray-500);
  font-style: italic;
  background: var(--bg-secondary);
  border-radius: var(--border-radius-md);
  margin: var(--space-6) 0;
}

.woocommerce-tabs #review_form_wrapper {
  margin-top: var(--space-8);
}

.woocommerce-tabs #review_form .comment-reply-title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin: 0 0 var(--space-6) 0;
}

.woocommerce-tabs #review_form .comment-form-rating {
  margin-bottom: var(--space-6);
}

.woocommerce-tabs #review_form .comment-form-rating label {
  display: block;
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  margin-bottom: var(--space-3);
}

.woocommerce-tabs #review_form .stars {
  display: flex;
  gap: var(--space-1);
}

.woocommerce-tabs #review_form .stars a {
  color: var(--color-gray-300);
  font-size: var(--text-2xl);
  transition: all var(--transition-fast);
  text-decoration: none;
}

.woocommerce-tabs #review_form .stars a:hover,
.woocommerce-tabs #review_form .stars a.active {
  color: #FFB800;
  transform: scale(1.1);
}

.woocommerce-tabs #review_form .comment-form label {
  display: block;
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  margin-bottom: var(--space-2);
}

.woocommerce-tabs #review_form .comment-form input[type="text"],
.woocommerce-tabs #review_form .comment-form input[type="email"],
.woocommerce-tabs #review_form .comment-form textarea {
  width: 100%;
  padding: var(--space-3);
  border: 2px solid var(--border-color);
  border-radius: var(--border-radius-md);
  font-family: var(--font-primary);
  font-size: var(--text-base);
  color: var(--color-secondary);
  background: var(--bg-primary);
  transition: all var(--transition-fast);
}

.woocommerce-tabs #review_form .comment-form input:focus,
.woocommerce-tabs #review_form .comment-form textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(0, 153, 204, 0.1);
}

.woocommerce-tabs #review_form .form-submit .submit {
  background: var(--gradient-primary);
  color: var(--color-white);
  border: none;
  padding: var(--space-4) var(--space-8);
  border-radius: var(--border-radius-md);
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  cursor: pointer;
  transition: all var(--transition-base);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.woocommerce-tabs #review_form .form-submit .submit:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-xl);
}

/* Tablet adjustments */
@media (max-width: 1024px) {
  .single-product div.product .woocommerce-product-gallery {
    flex: 0 0 400px;
    max-width: 400px;
  }
}

@media (max-width: 768px) {
  .single-product div.product {
    flex-direction: column;
    gap: var(--space-8);
  }

  .single-product div.product .woocommerce-product-gallery {
    flex: 1 1 auto;
    max-width: 100%;
    position: relative;
    top: 0;
  }

  .single-product div.product .woocommerce-product-gallery img {
    min-height: 300px;
    padding: var(--space-4);
  }

  .single-product div.product .product_title {
    font-size: var(--text-2xl);
  }

  .single-product div.product p.price {
    font-size: var(--text-3xl);
  }

  .single-product div.product form.cart {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }

  .single-product div.product form.cart .quantity {
    width: 100%;
  }

  .single-product div.product form.cart input[type="number"] {
    width: 100%;
  }

  .woocommerce-tabs ul.tabs {
    flex-direction: column;
  }

  .woocommerce-tabs ul.tabs li a {
    justify-content: flex-start;
    padding: var(--space-4);
  }

  .woocommerce-tabs .panel {
    padding: var(--space-6);
  }

  .woocommerce-cart .cart-collaterals {
    grid-template-columns: 1fr;
  }

  .woocommerce ul.products {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   SINGLE PRODUCT - Custom Template (sp-*)
   Structure matching Pencil design exactly
   ============================================ */

/* Single product page uses the same design tokens as the rest of the site */

/* --- Product Content: 2-column layout --- */
.sp-product-content {
  display: flex;
  gap: 40px;
  width: 100%;
  align-items: flex-start;
}

/* --- Gallery --- */
.sp-gallery {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 500px;
  flex-shrink: 0;
}

.sp-gallery__main {
  width: 100%;
  height: 500px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sp-gallery__image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sp-gallery__thumbs {
  display: flex;
  gap: 12px;
}

.sp-gallery__thumb {
  width: 80px;
  height: 80px;
  border-radius: var(--border-radius-sm);
  border: 1px solid var(--border-color);
  background: var(--bg-secondary);
  overflow: hidden;
  cursor: pointer;
  flex-shrink: 0;
}

.sp-gallery__thumb--active {
  border: 2px solid var(--color-primary);
}

.sp-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* --- Product Details --- */
.sp-details {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  font-family: var(--font-primary);
}

/* Title */
.sp-details__title {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  line-height: var(--leading-snug);
  margin: 0;
}

/* Meta Row: SKU | Stock */
.sp-details__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.sp-details__sku {
  font-size: var(--text-sm);
  font-weight: var(--font-normal);
  color: var(--color-gray-500);
}

.sp-details__meta-sep {
  font-size: var(--text-sm);
  color: var(--color-gray-300);
}

.sp-details__stock {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
}

.sp-details__stock--instock {
  color: var(--color-success);
}

.sp-details__stock--outofstock {
  color: var(--color-danger);
}

.sp-details__stock-dot {
  width: 8px;
  height: 8px;
  background: var(--color-success);
  border-radius: 50%;
  display: inline-block;
}

.sp-details__manifested {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-success);
}

.sp-details__manifested i {
  font-size: 14px;
}

/* Price Section */
.sp-details__price-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
  width: 100%;
}

.sp-details__price-row {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
}

.sp-details__price {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--font-extrabold);
  color: var(--color-secondary);
  line-height: 1;
}

.sp-details__price del {
  color: var(--color-gray-500);
  font-size: var(--text-base);
  font-weight: var(--font-medium);
}

.sp-details__price ins {
  text-decoration: none;
  font-size: var(--text-4xl);
  font-weight: var(--font-extrabold);
  color: var(--color-secondary);
}

.sp-details__price .woocommerce-Price-amount {
  font-family: var(--font-heading);
}

.sp-details__savings {
  display: inline-block;
  padding: 6px 12px;
  background: #E8F5E9;
  color: var(--color-success);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  border-radius: var(--border-radius-sm);
  width: fit-content;
}

/* Specifications */
.sp-details__specs {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.sp-details__specs-title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  margin: 0;
}

.sp-details__specs-list {
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.sp-details__specs-list ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.sp-details__specs-list li {
  padding: var(--space-4);
  border-bottom: 1px solid var(--border-color);
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  font-size: var(--text-sm);
  color: var(--color-secondary);
  background: var(--bg-primary);
  line-height: 1.5;
}

.sp-details__specs-list li:last-child {
  border-bottom: none;
}

.sp-details__specs-list li::before {
  content: "\2022";
  color: var(--color-gray-500);
  font-size: var(--text-base);
  margin-right: var(--space-2);
  flex-shrink: 0;
}

.sp-details__specs-list li strong {
  color: var(--color-gray-500);
  font-weight: var(--font-normal);
}

.sp-details__specs-list li em {
  color: var(--color-secondary);
  font-weight: var(--font-medium);
  font-style: normal;
  text-align: right;
}

/* Cart Form */
.sp-details__cart {
  width: 100%;
}

.sp-details__cart form.cart {
  display: flex;
  gap: 16px;
  align-items: flex-end;
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
}

.sp-details__cart .quantity {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sp-details__cart .quantity label {
  display: none !important;
}

.sp-details__cart .quantity::before {
  content: "QUANTITY";
  font-family: var(--font-heading);
  font-size: 11px;
  font-weight: var(--font-semibold);
  color: var(--color-gray-500);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.sp-details__cart input[type="number"] {
  width: 100px;
  height: 52px;
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  text-align: center;
  border: 2px solid var(--border-color);
  border-radius: var(--border-radius-sm);
  background: var(--color-white);
}

.sp-details__cart input[type="number"]:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(1, 94, 124, 0.1);
  outline: none;
}

.sp-details__cart .single_add_to_cart_button {
  flex: 1;
  height: 52px;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--border-radius-sm);
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.sp-details__cart .single_add_to_cart_button:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-brand);
}

.sp-details__cart .single_add_to_cart_button::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"%3E%3Ccircle cx="9" cy="21" r="1"/%3E%3Ccircle cx="20" cy="21" r="1"/%3E%3Cpath d="M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6"/%3E%3C/svg%3E');
  background-size: contain;
  background-repeat: no-repeat;
}

/* Categories & Tags */
.sp-details__categories {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-color);
  font-size: var(--text-sm);
  width: 100%;
}

.sp-details__cat-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.sp-details__cat-label {
  color: var(--color-gray-500);
  font-weight: var(--font-normal);
}

.sp-details__cat-value {
  color: var(--color-gray-500);
}

.sp-details__cat-value a {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: var(--font-medium);
}

.sp-details__cat-value a:hover {
  text-decoration: underline;
}

.sp-details__tag-sep {
  color: var(--color-gray-300);
  margin: 0 4px;
}

/* --- Manifest Preview Section --- */
.sp-manifest {
  width: 100%;
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  background: var(--bg-primary);
  overflow: hidden;
}

.sp-manifest__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-6);
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border-color);
  gap: var(--space-4);
}

.sp-manifest__header-left {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.sp-manifest__header-left > i {
  font-size: var(--text-2xl);
  color: var(--color-primary);
  flex-shrink: 0;
}

.sp-manifest__title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  margin: 0;
  line-height: var(--leading-tight);
}

.sp-manifest__subtitle {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  margin: 2px 0 0;
}

.sp-manifest__header-actions {
  display: flex;
  gap: var(--space-2);
  flex-shrink: 0;
}

/* Buttons */
.sp-manifest__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  padding: 10px 20px;
  border-radius: var(--border-radius-sm);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition-fast);
  line-height: 1;
}

.sp-manifest__btn--primary {
  background: var(--color-primary);
  color: var(--color-white);
}

.sp-manifest__btn--primary:hover {
  background: var(--color-primary-dark);
  color: var(--color-white);
  transform: translateY(-1px);
  box-shadow: var(--shadow-brand);
}

.sp-manifest__btn--outline {
  background: transparent;
  color: var(--color-primary);
  border: 1.5px solid var(--color-primary);
}

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

.sp-manifest__btn--download {
  background: var(--color-white);
  color: var(--color-primary);
  border: 1.5px solid var(--border-color);
}

.sp-manifest__btn--download:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
  box-shadow: var(--shadow-sm);
}

.sp-manifest__btn--expand {
  background: transparent;
  color: var(--color-primary);
  border: none;
  padding: var(--space-4) var(--space-6);
  width: 100%;
  justify-content: center;
  font-size: var(--text-sm);
}

.sp-manifest__btn--expand:hover {
  background: rgba(1, 94, 124, 0.04);
  color: var(--color-primary-dark);
}

.sp-manifest__btn--expand i {
  transition: transform var(--transition-fast);
}

/* Table */
.sp-manifest__table-wrap {
  max-height: none;
  overflow-x: auto;
}

.sp-manifest__table-wrap--expanded {
  max-height: 480px;
  overflow-y: auto;
}

.sp-manifest__table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.sp-manifest__table thead {
  position: sticky;
  top: 0;
  z-index: 2;
}

.sp-manifest__table th {
  background: var(--bg-secondary);
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--color-gray-500);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border-color);
  white-space: nowrap;
}

.sp-manifest__table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-secondary);
  border-bottom: 1px solid var(--color-gray-100);
  line-height: var(--leading-normal);
}

.sp-manifest__table td:first-child {
  color: var(--color-gray-400);
  font-size: var(--text-xs);
  width: 40px;
}

.sp-manifest__table tbody tr:hover {
  background: var(--color-gray-50);
}

.sp-manifest__table tbody tr:last-child td {
  border-bottom: none;
}

/* Footer */
.sp-manifest__footer {
  border-top: 1px solid var(--border-color);
}

/* Login CTA overlay for guests */
.sp-manifest__login-cta {
  position: relative;
}

.sp-manifest__login-overlay {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  background: linear-gradient(180deg, rgba(248,249,250,0.5) 0%, var(--color-gray-50) 100%);
}

.sp-manifest__login-overlay > i {
  font-size: var(--text-3xl);
  color: var(--color-gray-400);
}

.sp-manifest__login-overlay p {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  margin: 0;
  max-width: 320px;
}

.sp-manifest__login-buttons {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

/* Responsive */
@media (max-width: 768px) {
  .sp-manifest__header {
    flex-direction: column;
    align-items: flex-start;
  }

  .sp-manifest__header-actions {
    width: 100%;
  }

  .sp-manifest__btn--download {
    width: 100%;
    justify-content: center;
  }

  .sp-manifest__login-buttons {
    flex-direction: column;
    width: 100%;
  }

  .sp-manifest__login-buttons .sp-manifest__btn {
    width: 100%;
    justify-content: center;
  }

  .sp-manifest__table {
    font-size: var(--text-xs);
  }

  .sp-manifest__table th,
  .sp-manifest__table td {
    padding: var(--space-2) var(--space-3);
  }
}

/* --- Product Tabs --- */
.sp-tabs {
  width: 100%;
  margin-top: 0;
}

.sp-tabs .woocommerce-tabs {
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.sp-tabs .woocommerce-tabs ul.tabs {
  background: var(--bg-primary) !important;
  border-bottom: 1px solid var(--border-color) !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  gap: 0 !important;
  list-style: none !important;
  overflow: visible !important;
}

.sp-tabs .woocommerce-tabs ul.tabs li {
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  display: block !important;
  float: none !important;
}

.sp-tabs .woocommerce-tabs ul.tabs li::before,
.sp-tabs .woocommerce-tabs ul.tabs li::after {
  display: none !important;
  content: none !important;
}

body.single-product .sp-tabs .woocommerce-tabs ul.tabs li a,
.sp-tabs .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-medium) !important;
  color: var(--color-gray-500) !important;
  padding: var(--space-4) var(--space-6) !important;
  display: block !important;
  text-decoration: none !important;
  background: transparent !important;
  border-bottom: 3px solid transparent !important;
  transition: all var(--transition-fast) !important;
  margin: 0 !important;
}

body.single-product .sp-tabs .woocommerce-tabs ul.tabs li.active a,
.sp-tabs .woocommerce-tabs ul.tabs li.active a {
  color: var(--color-primary) !important;
  font-weight: var(--font-semibold) !important;
  border-bottom-color: var(--color-primary) !important;
}

body.single-product .sp-tabs .woocommerce-tabs ul.tabs li a:hover,
.sp-tabs .woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-primary) !important;
}

body.single-product .sp-tabs .woocommerce-tabs .panel,
.sp-tabs .woocommerce-tabs .panel {
  padding: var(--space-8) !important;
  background: var(--bg-primary) !important;
  margin: 0 !important;
}

body.single-product .sp-tabs .woocommerce-tabs .panel h2,
.sp-tabs .woocommerce-tabs .panel h2 {
  font-family: var(--font-heading) !important;
  font-size: var(--text-xl) !important;
  font-weight: var(--font-bold) !important;
  color: var(--color-secondary) !important;
  margin: 0 0 var(--space-5) 0 !important;
  padding: 0 !important;
  border: none !important;
}

.sp-tabs .woocommerce-tabs .panel p {
  font-family: var(--font-primary);
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}

.sp-tabs .woocommerce-tabs .panel ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.sp-tabs .woocommerce-tabs .panel ul li {
  font-family: var(--font-primary);
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-3);
  padding-left: 0;
}

.sp-tabs .woocommerce-tabs .panel ul li::before {
  content: "\2022";
  color: var(--color-gray-600);
  position: static;
  margin-right: 6px;
}

/* --- Responsive --- */
@media (max-width: 1024px) {
  .sp-gallery {
    width: 400px;
  }
  .sp-gallery__main {
    height: 400px;
  }
}

@media (max-width: 768px) {
  .sp-product-content {
    flex-direction: column;
    gap: 32px;
  }
  .sp-gallery {
    width: 100%;
  }
  .sp-gallery__main {
    height: 350px;
  }
  .sp-details__title {
    font-size: 24px;
  }
  .sp-details__price {
    font-size: 30px;
  }
  .sp-details__price ins {
    font-size: 30px;
  }
  .sp-details__cart form.cart {
    flex-direction: column;
    align-items: stretch;
  }
  .sp-details__cart input[type="number"] {
    width: 100%;
  }
  .sp-tabs .woocommerce-tabs ul.tabs {
    flex-direction: column;
  }
  .sp-tabs .woocommerce-tabs .panel {
    padding: 24px;
  }
}

/* Breadcrumbs */
body.single-product .woocommerce-breadcrumb {
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-normal);
  color: var(--color-gray-500);
  padding: 0 0 var(--space-4) 0;
  margin-bottom: 0;
  border-bottom: 1px solid var(--border-color);
}

body.single-product .woocommerce-breadcrumb a {
  color: var(--color-primary);
  font-weight: var(--font-normal);
}

body.single-product .woocommerce-breadcrumb .breadcrumb-separator {
  color: var(--color-gray-400);
  margin: 0 4px;
}

/* Main content wrapper - match Pencil design (1440px frame, 40px side padding = 1360px content) */
body.single-product .woocommerce-main .container {
  max-width: 1440px;
  width: 100%;
  padding: 32px 40px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 32px;
  box-sizing: border-box;
}

body.single-product .woocommerce-main .container > .product {
  display: flex;
  flex-direction: column;
  gap: 32px;
  width: 100%;
}

/* ============================================
   BLOCK CART - WooCommerce Gutenberg Blocks
   ============================================ */

/* Page wrapper */
.woocommerce-cart .woocommerce-page-wrapper {
  padding-bottom: var(--space-12);
}

.woocommerce-cart .woocommerce-page-wrapper > .container {
  max-width: var(--container-xl);
}

/* Main layout */
.woocommerce-cart .wc-block-cart .wc-block-components-sidebar-layout {
  gap: var(--space-8);
  align-items: flex-start;
}

/* Cart items table */
.woocommerce-cart .wc-block-cart-items {
  background: var(--bg-primary);
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.woocommerce-cart .wc-block-cart-items__header {
  background: transparent;
  border-bottom: 2px solid var(--border-color);
}

.woocommerce-cart .wc-block-cart-items__header th {
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  color: var(--color-secondary);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-4) var(--space-5);
}

/* Cart item rows */
.woocommerce-cart .wc-block-cart-items__row {
  border-bottom: 1px solid var(--border-color);
  transition: background var(--transition-fast);
}

.woocommerce-cart .wc-block-cart-items__row:hover {
  background: var(--color-gray-50);
}

.woocommerce-cart .wc-block-cart-items__row:last-child {
  border-bottom: none;
}

/* Product image */
.woocommerce-cart .wc-block-cart-item__image {
  padding: var(--space-4) var(--space-4) var(--space-4) var(--space-5);
}

.woocommerce-cart .wc-block-cart-item__image img {
  border-radius: var(--border-radius-md);
  border: 1px solid var(--border-color);
  object-fit: cover;
  width: 88px;
  height: 88px;
}

/* Product details */
.woocommerce-cart .wc-block-cart-item__product {
  padding: var(--space-4) var(--space-5);
}

.woocommerce-cart .wc-block-components-product-name {
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  font-size: var(--text-base);
  color: var(--color-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.woocommerce-cart .wc-block-components-product-name:hover {
  color: var(--color-primary);
}

/* Product price in item */
.woocommerce-cart .wc-block-cart-item__prices .wc-block-components-product-price__value {
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
}

/* Product metadata/description */
.woocommerce-cart .wc-block-components-product-metadata {
  margin-top: var(--space-1);
}

.woocommerce-cart .wc-block-components-product-metadata__description p {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  line-height: var(--leading-normal);
  margin: 0;
}

/* Quantity selector */
.woocommerce-cart .wc-block-components-quantity-selector {
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  background: var(--bg-primary);
  transition: border-color var(--transition-fast);
}

.woocommerce-cart .wc-block-components-quantity-selector:hover {
  border-color: var(--color-primary);
}

.woocommerce-cart .wc-block-components-quantity-selector__input {
  font-family: var(--font-heading);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  color: var(--color-secondary);
  width: 48px;
  text-align: center;
  border: none;
  background: transparent;
  padding: var(--space-2) 0;
}

.woocommerce-cart .wc-block-components-quantity-selector__button {
  background: var(--bg-secondary);
  border: none;
  color: var(--color-gray-600);
  cursor: pointer;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  transition: all var(--transition-fast);
  line-height: 1;
}

.woocommerce-cart .wc-block-components-quantity-selector__button:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

/* Remove item link */
.woocommerce-cart .wc-block-cart-item__remove-link {
  font-size: var(--text-xs);
  color: var(--color-gray-400);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  margin-top: var(--space-2);
  transition: color var(--transition-fast);
}

.woocommerce-cart .wc-block-cart-item__remove-link:hover {
  color: var(--color-danger);
}

/* Item total */
.woocommerce-cart .wc-block-cart-item__total {
  padding: var(--space-4) var(--space-5);
}

.woocommerce-cart .wc-block-cart-item__total .wc-block-components-product-price__value {
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  font-size: var(--text-lg);
  color: var(--color-primary);
}

/* ============================================
   BLOCK CART - Sidebar / Totals
   ============================================ */

.woocommerce-cart .wc-block-cart__sidebar {
  background: var(--bg-secondary);
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--border-color);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: calc(var(--header-height) + var(--space-4));
}

/* Totals title */
.woocommerce-cart .wc-block-cart__totals-title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 2px solid var(--border-color);
}

/* Coupon section */
.woocommerce-cart .wc-block-components-totals-coupon {
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  color: var(--color-primary);
}

.woocommerce-cart .wc-block-components-panel__button {
  font-size: var(--text-sm);
  color: var(--color-primary);
  font-weight: var(--font-medium);
}

/* Totals rows */
.woocommerce-cart .wc-block-components-totals-wrapper {
  border-top: 1px solid var(--border-color);
}

/* Footer total */
.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-secondary);
}

.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-components-totals-footer-item-tax-value {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}

/* Checkout button */
.woocommerce-cart .wc-block-cart__submit-button {
  width: 100%;
  background: var(--gradient-primary) !important;
  color: var(--color-white) !important;
  padding: var(--space-4) var(--space-6) !important;
  border: none !important;
  border-radius: var(--border-radius-md) !important;
  font-family: var(--font-heading) !important;
  font-size: var(--text-base) !important;
  font-weight: var(--font-bold) !important;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition: all var(--transition-base) !important;
  box-shadow: var(--shadow-md);
}

.woocommerce-cart .wc-block-cart__submit-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-brand) !important;
}

/* ============================================
   BLOCK CART - Responsive
   ============================================ */

@media (max-width: 768px) {
  .woocommerce-cart .woocommerce-products-header {
    padding: var(--space-8) 0;
  }

  .woocommerce-cart .woocommerce-products-header__title {
    font-size: var(--text-2xl);
  }

  .woocommerce-cart .wc-block-cart .wc-block-components-sidebar-layout {
    flex-direction: column;
  }

  .woocommerce-cart .wc-block-cart__sidebar {
    position: static;
    width: 100%;
    box-sizing: border-box;
    overflow: visible;
    /* Remove card styling on mobile - conflicts with WC sticky checkout */
    background: transparent;
    border: none;
    padding: 0;
    box-shadow: none;
  }

  .woocommerce-cart .wc-block-cart__main {
    width: 100%;
  }

  .woocommerce-cart .wc-block-cart-item__image img {
    width: 64px;
    height: 64px;
  }

  /* Show cart totals title (WC hides it on mobile) */
  .woocommerce-cart .wc-block-cart__totals-title {
    display: block !important;
  }

  /* Wrap the order summary in a card on mobile */
  .woocommerce-cart .wp-block-woocommerce-cart-order-summary-block {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-lg);
    padding: var(--space-5);
    padding-bottom: calc(var(--space-5) + 90px); /* Extra space for fixed checkout bar */
    box-shadow: var(--shadow-sm);
  }

  .woocommerce-cart .wc-block-cart__submit-button {
    font-size: var(--text-base) !important;
    padding: var(--space-4) !important;
  }

  /* Override WC sticky checkout bar background */
  .woocommerce-cart .wc-block-cart__submit-container--sticky {
    background-color: var(--color-white) !important;
    border-top: 1px solid var(--border-color);
    padding: var(--space-3) var(--space-4) !important;
  }
}

@media (max-width: 480px) {
  .woocommerce-cart .woocommerce-products-header {
    padding: var(--space-6) 0;
  }

  .woocommerce-cart .woocommerce-products-header__title {
    font-size: var(--text-xl);
  }
}

/* ============================================
   MY ACCOUNT PAGE
   ============================================ */

.woocommerce-account .woocommerce {
  display: grid !important;
  grid-template-columns: 260px 1fr;
  gap: var(--space-8);
  align-items: start;
  padding-bottom: var(--space-16);
}

/* Override WooCommerce default floats & widths */
.woocommerce-account .woocommerce-MyAccount-navigation {
  float: none !important;
  width: auto !important;
  grid-column: 1;
}

.woocommerce-account .woocommerce-MyAccount-content {
  float: none !important;
  width: auto !important;
  grid-column: 2;
}

/* ---- Navigation Sidebar ---- */

.woocommerce-MyAccount-navigation {
  background: var(--color-white);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  position: sticky;
  top: 100px;
}

.woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: var(--space-2) 0;
}

.woocommerce-MyAccount-navigation li {
  margin: 0;
}

.woocommerce-MyAccount-navigation li a {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-gray-600);
  text-decoration: none;
  transition: all var(--transition-fast);
  border-left: 3px solid transparent;
}

.woocommerce-MyAccount-navigation li a:hover {
  background: var(--color-gray-50);
  color: var(--color-primary);
}

.woocommerce-MyAccount-navigation li.is-active a {
  background: rgba(1, 94, 124, 0.06);
  color: var(--color-primary);
  border-left-color: var(--color-primary);
  font-weight: var(--font-semibold);
}

/* Nav icons via ::before pseudo-elements */
.woocommerce-MyAccount-navigation-link--dashboard a::before {
  content: '\F3FF';
  font-family: 'bootstrap-icons';
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.woocommerce-MyAccount-navigation-link--orders a::before {
  content: '\F12C';
  font-family: 'bootstrap-icons';
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.woocommerce-MyAccount-navigation-link--downloads a::before {
  content: '\F128';
  font-family: 'bootstrap-icons';
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.woocommerce-MyAccount-navigation-link--edit-address a::before {
  content: '\F3AB';
  font-family: 'bootstrap-icons';
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.woocommerce-MyAccount-navigation-link--edit-account a::before {
  content: '\F4DA';
  font-family: 'bootstrap-icons';
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.woocommerce-MyAccount-navigation-link--customer-logout a::before {
  content: '\F1C3';
  font-family: 'bootstrap-icons';
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.woocommerce-MyAccount-navigation-link--customer-logout {
  border-top: 1px solid var(--color-gray-100);
  margin-top: var(--space-2);
  padding-top: var(--space-2);
}

.woocommerce-MyAccount-navigation-link--customer-logout a {
  color: var(--color-danger);
}

.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
  background: #FEF2F2;
  color: var(--color-danger);
}

/* ---- Content Area ---- */

.woocommerce-MyAccount-content {
  background: var(--color-white);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-8);
  min-height: 300px;
}

.woocommerce-MyAccount-content > p:first-of-type {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}

.woocommerce-MyAccount-content > p a {
  color: var(--color-primary);
  font-weight: var(--font-medium);
  text-decoration: none;
}

.woocommerce-MyAccount-content > p a:hover {
  text-decoration: underline;
}

.woocommerce-MyAccount-content > p strong {
  color: var(--color-secondary-dark);
}

/* ---- Orders Table ---- */

.woocommerce-MyAccount-content .woocommerce-orders-table,
.woocommerce-MyAccount-content table.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
  font-size: var(--text-sm);
}

.woocommerce-MyAccount-content .woocommerce-orders-table thead th,
.woocommerce-MyAccount-content table.shop_table thead th {
  background: var(--color-gray-50);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-gray-500);
  font-weight: var(--font-semibold);
  border-bottom: 1px solid var(--border-color);
  text-align: left;
}

.woocommerce-MyAccount-content .woocommerce-orders-table td,
.woocommerce-MyAccount-content table.shop_table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-gray-100);
  vertical-align: middle;
  color: var(--color-secondary);
}

.woocommerce-MyAccount-content .woocommerce-orders-table tr:last-child td,
.woocommerce-MyAccount-content table.shop_table tr:last-child td {
  border-bottom: none;
}

.woocommerce-MyAccount-content .woocommerce-orders-table .woocommerce-button,
.woocommerce-MyAccount-content table.shop_table .woocommerce-button,
.woocommerce-MyAccount-content .woocommerce-orders-table .button,
.woocommerce-MyAccount-content table.shop_table .button {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  color: var(--color-primary);
  background: rgba(1, 94, 124, 0.06);
  border: 1px solid rgba(1, 94, 124, 0.15);
  border-radius: var(--border-radius-md);
  text-decoration: none;
  transition: all var(--transition-fast);
  cursor: pointer;
}

.woocommerce-MyAccount-content .woocommerce-orders-table .woocommerce-button:hover,
.woocommerce-MyAccount-content table.shop_table .woocommerce-button:hover,
.woocommerce-MyAccount-content .woocommerce-orders-table .button:hover,
.woocommerce-MyAccount-content table.shop_table .button:hover {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* My Account notices — override toast styles */
.woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-MyAccount-content .woocommerce-error {
  position: static !important;
  max-width: none !important;
  width: auto !important;
  animation: none !important;
  cursor: default !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5) !important;
  background: rgba(1, 94, 124, 0.05) !important;
  border: 1px solid rgba(1, 94, 124, 0.15) !important;
  border-left: 4px solid var(--color-primary) !important;
  border-radius: var(--border-radius-md) !important;
  color: var(--color-secondary);
  font-size: var(--text-sm);
  margin-bottom: var(--space-4) !important;
}

.woocommerce-MyAccount-content .woocommerce-message::before,
.woocommerce-MyAccount-content .woocommerce-info::before,
.woocommerce-MyAccount-content .woocommerce-error::before {
  display: inline-block !important;
  content: '\F431' !important;
  font-family: 'bootstrap-icons' !important;
  font-size: 18px;
  color: var(--color-primary);
}

.woocommerce-MyAccount-content .woocommerce-error {
  background: #FEF2F2 !important;
  border-color: #FECACA !important;
  border-left-color: var(--color-danger) !important;
}

.woocommerce-MyAccount-content .woocommerce-error::before {
  content: '\F33B' !important;
  color: var(--color-danger);
}

.woocommerce-MyAccount-content .woocommerce-message a.button,
.woocommerce-MyAccount-content .woocommerce-info a.button {
  margin-left: auto;
}

/* ---- Addresses ---- */

.woocommerce-MyAccount-content .woocommerce-Addresses {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}

.woocommerce-MyAccount-content .woocommerce-Address,
.woocommerce-MyAccount-content .woocommerce-Addresses .col-1,
.woocommerce-MyAccount-content .woocommerce-Addresses .col-2 {
  float: none !important;
  width: auto !important;
  max-width: none !important;
  clear: none !important;
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.woocommerce-MyAccount-content .woocommerce-Addresses .col-1 {
  grid-column: 1;
  grid-row: 1;
}

.woocommerce-MyAccount-content .woocommerce-Addresses .col-2 {
  grid-column: 2;
  grid-row: 1;
}

.woocommerce-MyAccount-content .woocommerce-Address-title,
.woocommerce-MyAccount-content .woocommerce-Address header.woocommerce-Address-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-5);
  background: var(--color-gray-50);
  border-bottom: 1px solid var(--border-color);
}

.woocommerce-MyAccount-content .woocommerce-Address-title h2,
.woocommerce-MyAccount-content .woocommerce-Address-title h3 {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-secondary-dark);
  margin: 0;
}

.woocommerce-MyAccount-content .woocommerce-Address-title a {
  font-size: var(--text-xs);
  color: var(--color-primary);
  text-decoration: none;
  font-weight: var(--font-medium);
  padding: 4px 10px;
  border-radius: var(--border-radius-sm);
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.woocommerce-MyAccount-content .woocommerce-Address-title a:hover {
  background: rgba(1, 94, 124, 0.06);
}

.woocommerce-MyAccount-content .woocommerce-Address address {
  padding: var(--space-4) var(--space-5);
  font-style: normal;
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}

/* ---- Edit Account Form ---- */

.woocommerce-MyAccount-content .woocommerce-EditAccountForm,
.woocommerce-MyAccount-content .edit-account {
  max-width: 600px;
}

.woocommerce-MyAccount-content fieldset {
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-md);
  padding: var(--space-5);
  margin: var(--space-6) 0;
}

.woocommerce-MyAccount-content fieldset legend {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-secondary-dark);
  padding: 0 var(--space-2);
}

.woocommerce-MyAccount-content .woocommerce-form-row,
.woocommerce-MyAccount-content .form-row {
  margin-bottom: var(--space-5);
}

.woocommerce-MyAccount-content .woocommerce-form-row label,
.woocommerce-MyAccount-content .form-row label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-gray-700);
  margin-bottom: var(--space-2);
}

.woocommerce-MyAccount-content .woocommerce-form-row label .required,
.woocommerce-MyAccount-content .form-row label .required {
  color: var(--color-danger);
}

.woocommerce-MyAccount-content .woocommerce-Input,
.woocommerce-MyAccount-content .input-text,
.woocommerce-MyAccount-content input[type="text"],
.woocommerce-MyAccount-content input[type="email"],
.woocommerce-MyAccount-content input[type="password"],
.woocommerce-MyAccount-content select,
.woocommerce-MyAccount-content textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  font-family: var(--font-primary);
  color: var(--color-secondary-dark);
  background: var(--color-white);
  border: 1.5px solid var(--color-gray-200);
  border-radius: var(--border-radius-md);
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  box-sizing: border-box;
}

.woocommerce-MyAccount-content .woocommerce-Input:focus,
.woocommerce-MyAccount-content .input-text:focus,
.woocommerce-MyAccount-content input[type="text"]:focus,
.woocommerce-MyAccount-content input[type="email"]:focus,
.woocommerce-MyAccount-content input[type="password"]:focus,
.woocommerce-MyAccount-content select:focus,
.woocommerce-MyAccount-content textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(1, 94, 124, 0.1);
}

/* Save button */
.woocommerce-MyAccount-content .woocommerce-Button,
.woocommerce-MyAccount-content button[type="submit"],
.woocommerce-MyAccount-content input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  font-family: var(--font-primary);
  color: var(--color-white);
  background: var(--gradient-primary);
  border: none;
  border-radius: var(--border-radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
  margin-top: var(--space-2);
}

.woocommerce-MyAccount-content .woocommerce-Button:hover,
.woocommerce-MyAccount-content button[type="submit"]:hover,
.woocommerce-MyAccount-content input[type="submit"]:hover {
  box-shadow: var(--shadow-brand);
  transform: translateY(-1px);
}

/* ---- My Account Responsive ---- */

@media (max-width: 768px) {
  .woocommerce-account .woocommerce {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .woocommerce-MyAccount-navigation,
  .woocommerce-account .woocommerce-MyAccount-content {
    grid-column: 1;
  }

  .woocommerce-MyAccount-navigation {
    position: static;
  }

  .woocommerce-MyAccount-navigation ul {
    display: flex;
    overflow-x: auto;
    gap: 0;
    padding: 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .woocommerce-MyAccount-navigation ul::-webkit-scrollbar {
    display: none;
  }

  .woocommerce-MyAccount-navigation li a {
    white-space: nowrap;
    padding: var(--space-3) var(--space-4);
    border-left: none;
    border-bottom: 3px solid transparent;
    font-size: var(--text-xs);
  }

  .woocommerce-MyAccount-navigation li.is-active a {
    border-left-color: transparent;
    border-bottom-color: var(--color-primary);
  }

  .woocommerce-MyAccount-navigation li a::before {
    display: none;
  }

  .woocommerce-MyAccount-navigation-link--customer-logout {
    border-top: none;
    margin-top: 0;
    padding-top: 0;
  }

  .woocommerce-MyAccount-content {
    padding: var(--space-5);
  }

  .woocommerce-MyAccount-content .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   GUEST PURCHASE RESTRICTION
   ============================================ */

/* Hide cart form for guests */
.sync-guest-hide-cart {
  display: none;
}

/* Login prompt on single product page */
.sync-login-to-buy {
  text-align: center;
  padding: var(--space-6) var(--space-5);
  border: 2px dashed var(--color-border, #e2e8f0);
  border-radius: var(--radius-lg, 12px);
  background: var(--color-surface-alt, #f8fafc);
  margin-bottom: var(--space-4);
}

.sync-login-to-buy .bi-lock {
  font-size: 2rem;
  color: var(--color-text-muted, #64748b);
  display: block;
  margin-bottom: var(--space-3);
}

.sync-login-to-buy__message {
  font-size: var(--text-base, 1rem);
  color: var(--color-text-secondary, #475569);
  margin: 0 0 var(--space-4);
  font-weight: 500;
}

.sync-login-to-buy__buttons {
  display: flex;
  gap: var(--space-3, 12px);
  justify-content: center;
  flex-wrap: wrap;
}

.sync-login-to-buy__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2-5, 10px) var(--space-5, 20px);
  border-radius: var(--radius-md, 8px);
  font-weight: 600;
  font-size: var(--text-sm, 0.875rem);
  text-decoration: none;
  transition: all 0.2s ease;
  min-width: 140px;
}

.sync-login-to-buy__btn--primary {
  background: var(--color-primary, #2563eb);
  color: #fff !important;
  border: 2px solid var(--color-primary, #2563eb);
}

.sync-login-to-buy__btn--primary:hover {
  background: var(--color-primary-dark, #1d4ed8);
  border-color: var(--color-primary-dark, #1d4ed8);
  color: #fff !important;
  transform: translateY(-1px);
}

.sync-login-to-buy__btn--secondary {
  background: transparent;
  color: var(--color-primary, #2563eb) !important;
  border: 2px solid var(--color-primary, #2563eb);
}

.sync-login-to-buy__btn--secondary:hover {
  background: var(--color-primary, #2563eb);
  color: #fff !important;
  transform: translateY(-1px);
}

/* "Sign in to Buy" link on shop/archive loop */
.sync-login-to-buy-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: transparent !important;
  color: var(--color-primary, #2563eb) !important;
  border: 2px solid var(--color-primary, #2563eb) !important;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
}

.sync-login-to-buy-link:hover {
  background: var(--color-primary, #2563eb) !important;
  color: #fff !important;
  transform: translateY(-1px);
}

/* Responsive */
@media (max-width: 480px) {
  .sync-login-to-buy__buttons {
    flex-direction: column;
    align-items: stretch;
  }

  .sync-login-to-buy__btn {
    min-width: unset;
  }
}

/* ============================================
   RETAIL PRICE ON PRODUCT CARDS
   ============================================ */

.woocommerce ul.products li.product .sync-retail-price {
  display: block;
  padding: 0 var(--space-4) var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  font-family: var(--font-primary);
  line-height: 1.4;
}

.woocommerce ul.products li.product .sync-retail-price .sync-retail-label {
  font-weight: var(--font-semibold);
  color: var(--color-gray-500);
  text-transform: uppercase;
  font-size: var(--text-xs);
  letter-spacing: 0.03em;
}

/* When product is on sale, restyle the price display */
.woocommerce ul.products li.product .price del {
  display: none;
}

.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  color: var(--color-primary);
}

/* ============================================
   CUSTOM SIDEBAR FILTERS
   ============================================ */

/* Active filters bar */
.sync-filter-active-bar {
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-color);
}

.sync-filter-clear-all {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  color: var(--color-danger);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  text-decoration: none;
  border-radius: var(--border-radius-md);
  transition: all var(--transition-fast);
  background: rgba(220, 53, 69, 0.06);
}

.sync-filter-clear-all:hover {
  background: rgba(220, 53, 69, 0.12);
  color: var(--color-danger);
}

/* Filter widget titles */
.sync-filter-widget .widget-title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.sync-filter-widget .widget-title i {
  font-size: var(--text-base);
  color: var(--color-primary);
}

/* Price Filter Form */
.sync-price-filter-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* Price Display Labels */
.sync-price-display {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
}

.sync-price-val {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}

.sync-price-dash {
  color: var(--color-gray-400);
  font-size: var(--text-xs);
}

/* Dual Range Slider */
.sync-range-slider {
  position: relative;
  height: 28px;
  display: flex;
  align-items: center;
  padding: 0 2px;
}

.sync-range-track {
  position: absolute;
  left: 2px;
  right: 2px;
  height: 4px;
  background: var(--border-color);
  border-radius: var(--border-radius-full);
}

.sync-range-fill {
  position: absolute;
  height: 100%;
  background: var(--color-primary);
  border-radius: var(--border-radius-full);
}

.sync-range-input {
  position: absolute;
  left: 0;
  width: 100%;
  height: 4px;
  -webkit-appearance: none;
  appearance: none;
  background: none;
  pointer-events: none;
  margin: 0;
  padding: 0;
}

.sync-range-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--bg-primary);
  border: 2.5px solid var(--color-primary);
  cursor: pointer;
  pointer-events: all;
  transition: box-shadow 0.15s ease;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}

.sync-range-input::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 5px rgba(1, 94, 124, 0.1), 0 1px 3px rgba(0,0,0,0.15);
}

.sync-range-input::-webkit-slider-thumb:active {
  box-shadow: 0 0 0 7px rgba(1, 94, 124, 0.15), 0 1px 3px rgba(0,0,0,0.15);
}

.sync-range-input::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--bg-primary);
  border: 2.5px solid var(--color-primary);
  cursor: pointer;
  pointer-events: all;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}

.sync-range-input::-moz-range-thumb:hover {
  box-shadow: 0 0 0 5px rgba(1, 94, 124, 0.1), 0 1px 3px rgba(0,0,0,0.15);
}

.sync-filter-btn {
  width: 100%;
  padding: var(--space-2) var(--space-4);
  background: var(--gradient-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--border-radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  font-family: var(--font-heading);
  cursor: pointer;
  transition: all var(--transition-fast);
  letter-spacing: 0.02em;
}

.sync-filter-btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-brand);
}

/* Chip/Pill Filters (Packaging, Manifested) */
.shop-sidebar .sync-chip-group {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: var(--space-2) !important;
}

.shop-sidebar a.sync-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 6px 12px !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius-full) !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  font-family: var(--font-primary) !important;
  color: var(--color-gray-600) !important;
  background: var(--bg-primary) !important;
  text-decoration: none !important;
  transition: all var(--transition-fast) !important;
  white-space: nowrap !important;
  line-height: 1 !important;
  transform: none !important;
}

.shop-sidebar a.sync-chip i {
  font-size: 12px;
}

.shop-sidebar a.sync-chip:hover {
  border-color: var(--color-primary) !important;
  color: var(--color-primary) !important;
  background: rgba(1, 94, 124, 0.06) !important;
}

.shop-sidebar a.sync-chip.active {
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  border-color: var(--color-primary) !important;
}

.shop-sidebar a.sync-chip.active:hover {
  background: var(--color-primary-dark) !important;
  border-color: var(--color-primary-dark) !important;
  color: var(--color-white) !important;
}

/* ============================================
   PAGINATION
   ============================================ */

.woocommerce-pagination {
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: 1px solid var(--border-color);
}

.woocommerce-pagination ul.page-numbers {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--space-2) !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  min-width: unset !important;
  height: auto !important;
}

.woocommerce-pagination ul.page-numbers li {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.woocommerce-pagination ul.page-numbers li a,
.woocommerce-pagination ul.page-numbers li span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 42px !important;
  height: 42px !important;
  padding: 0 var(--space-3) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--border-radius-md) !important;
  font-family: var(--font-heading) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--font-semibold) !important;
  color: var(--color-gray-700) !important;
  background: var(--bg-primary) !important;
  text-decoration: none !important;
  transition: all var(--transition-fast) !important;
  cursor: pointer !important;
  line-height: 1 !important;
}

.woocommerce-pagination ul.page-numbers li a:hover {
  background: var(--bg-secondary) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-primary) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.woocommerce-pagination ul.page-numbers li span.current {
  background: var(--gradient-primary) !important;
  color: var(--color-white) !important;
  border-color: transparent !important;
  box-shadow: var(--shadow-brand);
  cursor: default !important;
}

.woocommerce-pagination ul.page-numbers li a.next,
.woocommerce-pagination ul.page-numbers li a.prev {
  font-size: var(--text-lg) !important;
  color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  background: transparent !important;
}

.woocommerce-pagination ul.page-numbers li a.next:hover,
.woocommerce-pagination ul.page-numbers li a.prev:hover {
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
}

.woocommerce-pagination ul.page-numbers li span.dots {
  border: none !important;
  background: transparent !important;
  color: var(--color-gray-400) !important;
  cursor: default !important;
  min-width: 32px !important;
}

