/* ============================================
   Athens Ga Florist - WooCommerce Styles
   Category page, Single product, and Mini Cart
   ============================================ */

/* ===== 404 Page ===== */
.error-404-content {
  text-align: center;
  max-width: 560px;
}

.error-404-message {
  font-size: 1.1rem;
  color: var(--color-text-light);
  margin-bottom: 32px;
}

/* ===== Shop Content Section ===== */
.shop-content-section {
  padding-top: 32px;
}

/* ===== Product Detail Section ===== */
.product-detail-section {
  background: var(--color-white);
  padding-top: 40px;
}

/* ===== Tab Hidden State ===== */
.wc-tab-hidden {
  display: none;
}

/* ===== Products Grid Column Variants ===== */
.products-grid.grid-3-col {
  grid-template-columns: repeat(3, 1fr);
}

.products-grid.grid-4-col {
  grid-template-columns: repeat(4, 1fr);
}

/* ===== Cart Count Bump Animation ===== */
.cart-count-bump {
  animation: cartBump 0.3s ease;
}

@keyframes cartBump {
  0% { transform: scale(1); }
  50% { transform: scale(1.3); }
  100% { transform: scale(1); }
}

/* ===== Page Hero (Category Pages) ===== */
.page-hero {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-secondary-dark) 50%, var(--color-secondary) 100%);
  padding: 48px 0 52px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(201, 169, 110, 0.15) 0%, transparent 60%),
              radial-gradient(ellipse at 80% 50%, rgba(107, 91, 149, 0.2) 0%, transparent 60%);
  pointer-events: none;
}

.page-hero .container {
  position: relative;
  z-index: 1;
}

.page-hero h1 {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  margin-bottom: 10px;
  color: var(--color-white);
}

.page-hero p {
  color: rgba(255, 255, 255, 0.75);
  font-size: 1.05rem;
  max-width: 520px;
  margin: 0 auto;
}

/* ===== Breadcrumb ===== */
.breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 20px;
  background: rgba(255, 255, 255, 0.1);
  padding: 8px 20px;
  border-radius: var(--radius-full);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.breadcrumb a {
  color: rgba(255, 255, 255, 0.8);
  font-weight: 500;
  transition: color var(--transition);
}

.breadcrumb a:hover {
  color: var(--color-white);
}

.breadcrumb .separator {
  font-size: 0.8rem;
  color: var(--color-accent);
  font-weight: 700;
}

.breadcrumb [aria-current="page"] {
  color: var(--color-white);
  font-weight: 600;
}

/* ===== Shop Toolbar ===== */
.shop-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  padding: 20px 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 32px;
}

.shop-toolbar-left {
  display: flex;
  align-items: center;
  gap: 16px;
}

.filter-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  font-size: 0.88rem;
  font-weight: 500;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  color: var(--color-text);
  transition: all var(--transition);
  cursor: pointer;
}

.filter-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
}

.filter-btn svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}

.filter-btn.active {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
}

.view-toggle {
  display: flex;
  gap: 4px;
}

.view-toggle button {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-white);
  color: var(--color-text-muted);
  transition: all var(--transition);
  cursor: pointer;
}

.view-toggle button.active,
.view-toggle button:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
  background: var(--color-primary-light);
}

.view-toggle button svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}

.shop-toolbar-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* WooCommerce ordering select override */
.woocommerce-ordering .orderby,
.sort-select {
  padding: 10px 36px 10px 16px;
  font-size: 0.88rem;
  font-family: var(--font-body);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  color: var(--color-text);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  cursor: pointer;
  transition: border-color var(--transition);
}

.woocommerce-ordering .orderby:hover,
.woocommerce-ordering .orderby:focus,
.sort-select:hover,
.sort-select:focus {
  border-color: var(--color-primary);
  outline: none;
}

.woocommerce-ordering {
  margin: 0;
}

/* ===== Shop Layout ===== */
.shop-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 40px;
  align-items: start;
  transition: grid-template-columns 0.3s ease;
}

.shop-layout.sidebar-hidden {
  grid-template-columns: 1fr;
}

.shop-layout.sidebar-hidden .shop-sidebar {
  display: none;
}

.shop-sidebar {
  position: sticky;
  top: 100px;
  transition: all 0.3s ease;
}

/* ===== List View ===== */
.products-grid.list-view {
  grid-template-columns: 1fr !important;
  gap: 16px;
}

.products-grid.list-view .product-card {
  display: grid;
  grid-template-columns: 220px 1fr auto;
  grid-template-rows: 1fr;
  align-items: center;
}

.products-grid.list-view .product-card-image {
  aspect-ratio: 1;
  height: 100%;
  min-height: 180px;
}

.products-grid.list-view .product-card-body {
  padding: 20px 24px;
}

.products-grid.list-view .product-card-footer {
  padding: 20px 24px 20px 0;
  display: flex;
  align-items: center;
}

.products-grid.list-view .add-to-cart-btn {
  white-space: nowrap;
}

/* ===== Filter Sidebar ===== */
.filter-group {
  margin-bottom: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--color-border);
}

.filter-group:last-child {
  border-bottom: none;
}

.filter-group-title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 16px;
  color: var(--color-text);
}

.filter-list li {
  margin-bottom: 10px;
}

.filter-list a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.9rem;
  color: var(--color-text-light);
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  transition: all var(--transition);
}

.filter-list a:hover,
.filter-list a.active {
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
}

.filter-list .count {
  font-size: 0.78rem;
  color: var(--color-text-muted);
  background: var(--color-cream-dark);
  padding: 2px 8px;
  border-radius: var(--radius-full);
}

.filter-list a.active .count {
  background: var(--color-primary);
  color: var(--color-white);
}

.filter-clear a {
  font-size: 0.82rem;
  color: var(--color-text-muted);
  justify-content: flex-start;
  gap: 4px;
}

.filter-clear a:hover {
  color: var(--color-primary);
  background: transparent;
}

.price-range {
  display: flex;
  gap: 12px;
  align-items: center;
}

.price-input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  font-family: var(--font-body);
  text-align: center;
  outline: none;
  transition: border-color var(--transition);
}

.price-input:focus {
  border-color: var(--color-primary);
}

.price-range-sep {
  color: var(--color-text-muted);
  font-weight: 500;
}

.filter-apply-btn {
  width: 100%;
  margin-top: 12px;
  padding: 10px;
  background: var(--color-primary);
  color: var(--color-white);
  font-weight: 600;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  border: none;
  cursor: pointer;
}

.filter-apply-btn:hover {
  background: var(--color-primary-dark);
}

/* ===== Category Chips ===== */
.category-chips {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}

.category-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  font-size: 0.82rem;
  font-weight: 500;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-white);
  color: var(--color-text-light);
  transition: all var(--transition);
  white-space: nowrap;
}

.category-chip:hover,
.category-chip.active {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: var(--color-white);
}

.category-chip img {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
}

/* ===== Pagination ===== */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--color-border);
}

.pagination a,
.pagination span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 12px;
  font-size: 0.9rem;
  font-weight: 500;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  transition: all var(--transition);
}

.pagination a:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
  background: var(--color-primary-light);
}

.pagination .current,
.pagination span.current {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.pagination .dots {
  border: none;
  min-width: auto;
  color: var(--color-text-muted);
}

.pagination .prev,
.pagination .next {
  font-weight: 600;
  gap: 4px;
}

/* Sidebar overlay for mobile */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 1000;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.sidebar-overlay.open {
  display: block;
  opacity: 1;
}

.sidebar-close {
  display: none;
  width: 100%;
  padding: 12px;
  margin-bottom: 16px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text);
  background: var(--color-cream);
  border-radius: var(--radius-sm);
  text-align: center;
  transition: all var(--transition);
  border: none;
  cursor: pointer;
}

.sidebar-close:hover {
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
}

/* ===== Single Product: Breadcrumb Hero ===== */
.product-breadcrumb {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-secondary-dark) 50%, var(--color-secondary) 100%);
  padding: 40px 0 44px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.product-breadcrumb::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(201, 169, 110, 0.15) 0%, transparent 60%),
              radial-gradient(ellipse at 80% 50%, rgba(107, 91, 149, 0.2) 0%, transparent 60%);
  pointer-events: none;
}

.product-breadcrumb .container {
  position: relative;
  z-index: 1;
}

.breadcrumb-inner {
  padding: 0;
}

.product-hero-title {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 600;
  color: var(--color-white);
  margin-bottom: 14px;
}

.product-hero-subtitle {
  color: rgba(255, 255, 255, 0.65);
  font-size: 0.92rem;
  margin-bottom: 18px;
}

/* ===== Product Layout ===== */
.product-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
  padding-bottom: 60px;
}

/* Product info column must be single column â€” no internal float/grid from plugins */
.product-info,
.product-info > * {
  width: 100%;
  max-width: 100%;
  float: none;
}

/* ===== WooCommerce Product Add-Ons Plugin =====
   The plugin uses column-count / float layout internally.
   Force everything into a single full-width column.
   ================================================ */

/* Top-level container */
.wc-pao-addons-container {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  clear: both !important;
  column-count: 1 !important;
  columns: 1 !important;
  -webkit-columns: 1 !important;
  -moz-columns: 1 !important;
  grid-template-columns: 1fr !important;
}

/* Every wrapper/row inside */
.wc-pao-addon-wrap {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  clear: both !important;
  break-inside: avoid;
  column-span: all !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Each individual addon field */
.wc-pao-addon {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  clear: both !important;
  margin-bottom: 16px !important;
  padding: 0 !important;
  box-sizing: border-box;
}

.wc-pao-addon-name,
.wc-pao-addon-required-header,
.wc-pao-addon > p:first-child,
.wc-pao-addon > label {
  display: block !important;
  font-weight: 600 !important;
  font-size: 0.92rem !important;
  color: var(--color-text) !important;
  margin-bottom: 8px !important;
  width: 100% !important;
  float: none !important;
}

.wc-pao-addon-content {
  display: block !important;
  width: 100% !important;
  float: none !important;
  clear: both !important;
}

/* Select dropdowns */
.wc-pao-addon select {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 11px 36px 11px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-white);
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  cursor: pointer;
  transition: border-color var(--transition);
  box-sizing: border-box;
}

.wc-pao-addon select:focus {
  border-color: var(--color-primary);
  outline: none;
}

/* Totals table */
.wc-pao-totals-table {
  width: 100% !important;
  float: none !important;
  clear: both !important;
  margin: 16px 0;
  font-size: 0.88rem;
  border-collapse: collapse;
}

.wc-pao-totals-table td {
  padding: 5px 0;
  color: var(--color-text-light);
  vertical-align: top;
}

.wc-pao-totals-table .wc-pao-totals-line-total {
  text-align: right;
  font-weight: 500;
  color: var(--color-text);
  white-space: nowrap;
  padding-left: 16px;
}

.wc-pao-totals-table .wc-pao-totals-subtotal td {
  font-weight: 700;
  color: var(--color-text);
  border-top: 1px solid var(--color-border);
  padding-top: 10px;
}

/* ===== Product Gallery ===== */
.product-gallery {
  position: sticky;
  top: 100px;
}

.product-gallery-main {
  width: 100%;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-cream);
  margin-bottom: 16px;
  position: relative;
}

.product-gallery-main img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: contain;
  cursor: zoom-in;
  transition: transform 0.4s ease;
}

.product-gallery-main:hover img {
  transform: scale(1.05);
}

.gallery-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  padding: 6px 16px;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  z-index: 2;
}

.product-thumbnails {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}

.product-thumbnail {
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition);
  background: var(--color-cream);
}

.product-thumbnail:hover,
.product-thumbnail.active {
  border-color: var(--color-primary);
}

.product-thumbnail img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}

/* ===== Product Info ===== */
.product-info {
  padding-top: 8px;
}

.product-info-category {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-primary);
  margin-bottom: 8px;
}

.product-info h1,
.product_title {
  font-size: 2.2rem;
  margin-bottom: 12px;
  line-height: 1.2;
}

.product-info-rating {
  display: none;
}

.product-price-block {
  margin-bottom: 24px;
}

.product-price-main {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  font-family: var(--font-heading);
}

.product-price-main del {
  font-size: 1.2rem;
  color: var(--color-text-muted);
}

.product-price-main ins {
  text-decoration: none;
}

.product-price-note {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin-top: 4px;
}

.product-description {
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--color-text-light);
  margin-bottom: 28px;
}

/* ===== Variations / Size Options ===== */
/* ===== Variations & Swatches ===== */

.variations_form .variations {
  margin-bottom: 24px;
}

.variations_form .variations tr {
  display: block;
  margin-bottom: 20px;
}

.variations_form .variations td {
  display: block;
  padding: 0;
}

.variations_form .variations td.label {
  padding-bottom: 8px;
}

.variations_form .variations td.label label,
.product-option-label {
  display: block;
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--color-text);
  margin: 0;
}

/* Hide native select â€” JS replaces with swatch buttons */
.variations_form .variations td.value select.swatch-hidden-select {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
  clip: rect(0,0,0,0);
  border: 0;
}

/* Fallback select style â€” shown only before JS runs */
.variations_form .variations td.value select:not(.swatch-hidden-select) {
  width: 100%;
  padding: 12px 16px;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  font-weight: 500;
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-white);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  transition: border-color var(--transition);
}

.variations_form .variations td.value select:not(.swatch-hidden-select):focus {
  border-color: var(--color-primary);
  outline: none;
}

/* Reset link */
.variations_form .reset_variations {
  display: block;
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin-top: 6px;
  text-decoration: underline;
}

/* Swatch options wrapper â€” flex wrap, handles many options */
.swatch-options,
.size-options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}

/* Individual swatch button â€” matches product.html exactly */
.size-option {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  min-width: 90px;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 0.88rem;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition), color var(--transition);
  line-height: 1.3;
}

.size-option:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
  background: var(--color-cream);
}

.size-option.active {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
}

/* Name line inside swatch */
.size-option .size-name {
  display: block;
  font-weight: 600;
  font-size: 0.88rem;
  line-height: 1.2;
}

/* Price line inside swatch */
.size-option .size-price {
  display: block;
  font-size: 0.78rem;
  color: var(--color-text-muted);
  margin-top: 3px;
  font-weight: 400;
}

.size-option.active .size-price {
  color: var(--color-primary-dark);
}

/* Many-options strategy: when there are 6+ swatches they wrap naturally.
   Cap width so they stay readable on all screen sizes. */
.swatch-options .size-option,
.size-options .size-option {
  flex: 0 0 auto;
  max-width: 160px;
}

/* ===== Add-on Options ===== */
.addon-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.addon-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition);
}

.addon-option:hover {
  border-color: var(--color-primary-light);
  background: var(--color-cream);
}

.addon-option input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-primary);
  cursor: pointer;
}

.addon-option-text {
  flex: 1;
  font-size: 0.9rem;
}

.addon-option-price {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-text);
}

/* ===== Quantity & Add to Cart ===== */

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Add to Cart Row
   DOM order: .qty-minus | .quantity | .qty-plus | .single_add_to_cart_button | .wishlist-btn
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* form.cart â€” ALWAYS block so variations + addons stack vertically */
.product-info form.cart,
.product-info form.cart.cart {
  display: block !important;
  margin-bottom: 24px;
}

/* Variable product: WC wraps qty+button in this div â€” flex row */
.woocommerce-variation-add-to-cart {
  display: flex !important;
  align-items: center;
  gap: 0;
  flex-wrap: nowrap;
  margin-top: 16px;
}

/* Simple product: qty-minus, .quantity, qty-plus, and button
   are direct children of form.cart â€” lay them out inline */
.product-info form.cart > .qty-minus,
.product-info form.cart > .quantity,
.product-info form.cart > .qty-plus,
.product-info form.cart > .single_add_to_cart_button,
.product-info form.cart > .wishlist-btn {
  display: inline-flex !important;
  vertical-align: middle;
}

/* Disabled variation state â€” keep visible but let JS handle validation */
.woocommerce-variation-add-to-cart-disabled {
  opacity: 1;
}

/* â”€â”€ Quantity stepper: [âˆ’] [input] [+] â”€â”€ */

.product-info .qty-minus,
.product-info .qty-plus {
  width: 44px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-cream);
  border: 1px solid var(--color-border);
  font-size: 1.3rem;
  line-height: 1;
  color: var(--color-text);
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--transition), color var(--transition);
}

.product-info .qty-minus {
  border-right: none;
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  margin-right: 0;
}

.product-info .qty-plus {
  border-left: none;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin-right: 12px; /* gap before ATC button */
}

.product-info .qty-minus:hover,
.product-info .qty-plus:hover {
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
}

/* .quantity div â€” just the input wrapper, no extra borders */
.product-info .quantity {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  height: 48px;
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
}

/* Qty input */
.product-info .quantity input.qty {
  width: 52px;
  height: 48px;
  text-align: center;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  border-left: none;
  border-right: none;
  font-size: 0.95rem;
  font-weight: 600;
  font-family: var(--font-body);
  outline: none;
  -moz-appearance: textfield;
  background: var(--color-white);
  color: var(--color-text);
  border-radius: 0;
}

.product-info .quantity input.qty::-webkit-outer-spin-button,
.product-info .quantity input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* â”€â”€ Add to Cart button â”€â”€ */
.woocommerce-variation-add-to-cart .single_add_to_cart_button,
.product-info form.cart .single_add_to_cart_button,
.product-info .single_add_to_cart_button {
  flex: 1;
  height: 48px;
  padding: 0 28px;
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 1rem;
  font-weight: 600;
  font-family: var(--font-body);
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
  min-width: 160px;
}

.woocommerce-variation-add-to-cart .single_add_to_cart_button:hover,
.product-info form.cart .single_add_to_cart_button:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover);
}

/* â”€â”€ Wishlist button (after ATC) â”€â”€ */
.product-info .wishlist-btn {
  margin-left: 12px;
  flex-shrink: 0;
}

/* Legacy quantity-selector */
.quantity-selector {
  display: flex;
  align-items: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--color-white);
  height: 48px;
}

/* quantity-input: for non-WC qty selectors */
.quantity-input {
  width: 52px;
  height: 48px;
  text-align: center;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  border-left: none;
  border-right: none;
  font-size: 0.95rem;
  font-weight: 600;
  font-family: var(--font-body);
  outline: none;
  -moz-appearance: textfield;
  background: var(--color-white);
  color: var(--color-text);
}

.quantity-input::-webkit-outer-spin-button,
.quantity-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* add-to-cart-main: used outside single product context */
.add-to-cart-main {
  flex: 1;
  height: 48px;
  padding: 0 28px;
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 1rem;
  font-weight: 600;
  font-family: var(--font-body);
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}

.add-to-cart-main:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover);
}

/* â”€â”€ Add to Cart: error & success messages â”€â”€ */
.bf-atc-error,
.bf-atc-success {
  margin-top: 12px;
  padding: 11px 16px;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.4;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* error div uses display:flex when visible; hidden attr collapses it */
.bf-atc-error[hidden] { display: none; }

.bf-atc-error {
  background: #fff0f0;
  border: 1px solid #f5c2c2;
  color: #c0392b;
}

.bf-atc-error::before {
  content: 'âš ';
  font-size: 1rem;
  flex-shrink: 0;
}

/* Legacy inline success (kept for non-single-product contexts) */
.bf-atc-success {
  background: #f0faf4;
  border: 1px solid #a8d5b5;
  color: #1e7e34;
}

.bf-atc-success::before {
  content: 'âœ“';
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* -------------------------------------------------------
   ATC Success Banner â€” below hero on single product page
   ------------------------------------------------------- */
.bf-atc-success-banner {
  display: none; /* hidden by default; JS adds .visible */
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 14px 24px;
  background: linear-gradient(90deg, #eaf7ee 0%, #f4fbf6 100%);
  border-top: 1px solid #b8dfc4;
  border-bottom: 3px solid var(--color-secondary);
  color: #1a5e2e;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 500;
  /* No margin â€” sits flush between .product-breadcrumb and .product-detail-section */
}

.bf-atc-success-banner.visible {
  display: flex;
  animation: bfBannerSlideDown 0.35s cubic-bezier(0.4, 0, 0.2, 1) both;
}

@keyframes bfBannerSlideDown {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bf-atc-success-banner svg:first-child {
  width: 20px;
  height: 20px;
  stroke: #1a7a37;
  stroke-width: 2.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
  background: #c6edd4;
  border-radius: var(--radius-full);
  padding: 3px;
}

.bf-atc-success-banner__cta {
  margin-left: auto;
  padding: 7px 18px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: background var(--transition), transform var(--transition);
  flex-shrink: 0;
}

.bf-atc-success-banner__cta:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
  color: var(--color-white);
}

.bf-atc-success-banner__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: var(--radius-full);
  flex-shrink: 0;
  transition: background var(--transition);
  padding: 0;
}

.bf-atc-success-banner__close:hover {
  background: rgba(0, 0, 0, 0.08);
}

.bf-atc-success-banner__close svg {
  width: 14px;
  height: 14px;
  stroke: #1a5e2e;
  stroke-width: 2;
  stroke-linecap: round;
}

/* On mobile: hide the banner (mobile bar handles it instead) */
@media (max-width: 768px) {
  .bf-atc-success-banner {
    display: none !important;
  }
}

.wishlist-btn {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-light);
  transition: all var(--transition);
  flex-shrink: 0;
  background: var(--color-white);
  cursor: pointer;
}

.wishlist-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: var(--color-primary-light);
}

/* Active/wishlisted state on single product page */
.wishlist-btn.active {
  border-color: #e05050;
  color: #e05050;
  background: #fdecea;
}

.wishlist-btn.active:hover {
  background: #e05050;
  color: var(--color-white);
}

.wishlist-btn .icon-heart {
  fill: none;
  stroke: currentColor;
  transition: fill var(--transition), stroke var(--transition);
}

.wishlist-btn.active .icon-heart {
  fill: #e05050;
  stroke: #e05050;
}

/* ===== Product card SVG icons ===== */
.quick-action-btn svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  display: block;
  pointer-events: none;
}

/* Heart fill when active (wishlisted) */
.wishlist-toggle .icon-heart {
  fill: none;
  stroke: currentColor;
  transition: fill var(--transition), stroke var(--transition);
}

.wishlist-toggle.active .icon-heart {
  fill: #e05050;
  stroke: #e05050;
}

.wishlist-toggle.active {
  background: #fdecea;
  color: #e05050;
}

.wishlist-toggle.active:hover {
  background: #e05050;
  color: var(--color-white);
}

/* ===== Wishlist Page ===== */
.wishlist-page {
  padding: 40px 0;
}

.wishlist-empty {
  text-align: center;
  padding: 80px 20px;
}

.wishlist-empty-icon {
  font-size: 4rem;
  color: var(--color-border);
  margin-bottom: 24px;
  line-height: 1;
}

.wishlist-empty h2 {
  font-family: var(--font-heading);
  font-size: 1.8rem;
  color: var(--color-text);
  margin-bottom: 12px;
}

.wishlist-empty p {
  color: var(--color-text-muted);
  margin-bottom: 28px;
  font-size: 1rem;
}

.wishlist-header {
  margin-bottom: 28px;
}

.wishlist-count {
  font-size: 0.92rem;
  color: var(--color-text-muted);
  font-weight: 500;
  margin: 0;
}

.wishlist-grid {
  margin-top: 0;
}

/* ===== Product Meta ===== */
.product-meta {
  padding: 20px 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 24px;
}

.product-meta-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 8px;
  font-size: 0.88rem;
}

.product-meta-row:last-child {
  margin-bottom: 0;
}

.product-meta-label {
  font-weight: 600;
  color: var(--color-text);
  min-width: 80px;
}

.product-meta-value {
  color: var(--color-text-light);
}

.product-meta-value a {
  color: var(--color-primary);
}

.product-meta-value a:hover {
  text-decoration: underline;
}

/* ===== Delivery Promises ===== */
.delivery-promises {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.delivery-promise {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.9rem;
}

.delivery-promise-icon {
  width: 40px;
  height: 40px;
  background: var(--color-cream);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.delivery-promise strong {
  display: block;
  font-size: 0.88rem;
}

.delivery-promise span {
  font-size: 0.82rem;
  color: var(--color-text-muted);
}

/* ===== Product Tabs ===== */
.product-tabs-section {
  padding: 60px 0;
  background: var(--color-white);
}

.woocommerce-tabs .wc-tabs,
.product-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--color-border);
  margin-bottom: 32px;
  list-style: none;
  padding: 0;
}

.woocommerce-tabs .wc-tabs li,
.product-tab {
  margin: 0;
}

.woocommerce-tabs .wc-tabs li a,
.product-tab {
  padding: 14px 28px;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-text-light);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--transition);
  display: block;
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
}

.woocommerce-tabs .wc-tabs li a:hover,
.product-tab:hover {
  color: var(--color-text);
}

.woocommerce-tabs .wc-tabs li.active a,
.product-tab.active {
  color: var(--color-primary-dark);
  border-bottom-color: var(--color-primary);
  font-weight: 600;
}

.woocommerce-Tabs-panel,
.tab-content {
  animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.woocommerce-Tabs-panel h3,
.tab-content h3 {
  font-size: 1.2rem;
  margin-bottom: 16px;
}

.woocommerce-Tabs-panel p,
.tab-content p {
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--color-text-light);
  margin-bottom: 16px;
}

.woocommerce-Tabs-panel ul,
.tab-content ul {
  padding-left: 20px;
  list-style: disc;
}

.woocommerce-Tabs-panel ul li,
.tab-content ul li {
  font-size: 0.92rem;
  line-height: 1.8;
  color: var(--color-text-light);
  margin-bottom: 4px;
}

/* ===== Reviews (WooCommerce) ===== */
#reviews .woocommerce-Reviews-title {
  font-size: 1.2rem;
  margin-bottom: 24px;
}

.woocommerce-review {
  padding: 24px 0;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-review:last-child {
  border-bottom: none;
}

.woocommerce-review .comment-text {
  margin: 0;
}

.woocommerce-review .meta {
  margin-bottom: 8px;
}

.woocommerce-review .meta strong {
  font-weight: 600;
  font-size: 0.95rem;
}

.woocommerce-review .meta time {
  font-size: 0.82rem;
  color: var(--color-text-muted);
}

.woocommerce-review .star-rating {
  color: var(--color-accent);
  margin-bottom: 10px;
}

.woocommerce-review .description p {
  font-size: 0.92rem;
  line-height: 1.7;
  color: var(--color-text-light);
}

/* ===== Related Products ===== */
.related-products {
  padding: 60px 0 72px;
  background: var(--color-cream);
}

.related-products .section-header {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 40px;
}

.related-products .section-header h2 {
  font-size: 2rem;
  margin-bottom: 10px;
}

.related-products .section-header p {
  font-size: 0.95rem;
  color: var(--color-text-muted);
}

.related-products .products-grid,
.related.products .products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

/* ===== Mini Cart ===== */
.mini-cart-wrapper {
  position: relative;
}

.mini-cart-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  width: 360px;
  background: var(--color-white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-border);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: all 0.25s ease;
  z-index: 1001;
  max-height: 480px;
  overflow-y: auto;
}

.mini-cart-wrapper:hover .mini-cart-dropdown,
.mini-cart-wrapper.open .mini-cart-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(4px);
}

.mini-cart-contents {
  padding: 16px;
}

.mini-cart-contents .woocommerce-mini-cart__empty-message {
  text-align: center;
  padding: 24px 16px;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.mini-cart-contents .woocommerce-mini-cart {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* â”€â”€ Mini cart item: [image | content | Ã—]
   Layout: image col 1, content col 2, Ã— remove col 3
   Product name is wrapped in .bf-cart-item-name via PHP filter â”€â”€ */
.mini-cart-contents .woocommerce-mini-cart-item {
  display: grid;
  grid-template-columns: 68px 1fr 24px;
  grid-template-areas:
    "img name    remove"
    "img addons  remove"
    "img qty     remove";
  align-items: start;
  gap: 0 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--color-border);
}

.mini-cart-contents .woocommerce-mini-cart-item:last-child {
  border-bottom: none;
}

.mini-cart-contents .woocommerce-mini-cart-item > a:not(.remove) {
  grid-area: img;
  grid-row: 1 / span 3;
}

.mini-cart-contents .woocommerce-mini-cart-item img {
  width: 68px;
  height: 68px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  display: block;
}

.mini-cart-contents .woocommerce-mini-cart-item .remove {
  grid-area: remove;
  grid-row: 1;
  color: var(--color-text-muted);
  font-size: 1rem;
  line-height: 1;
  align-self: start;
  text-align: right;
}

.mini-cart-contents .woocommerce-mini-cart-item .bf-cart-item-name {
  grid-area: name;
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.4;
}

.mini-cart-contents .woocommerce-mini-cart-item .bf-cart-item-name a {
  color: var(--color-text);
  font-weight: 700;
}

.mini-cart-contents .woocommerce-mini-cart-item dl.variation,
.mini-cart-contents .woocommerce-mini-cart-item dl {
  grid-area: addons;
  margin: 4px 0 0;
  display: block;
  font-size: 0.8rem;
  color: var(--color-text-light);
  line-height: 1.7;
}

.mini-cart-contents .woocommerce-mini-cart-item dl.variation dt,
.mini-cart-contents .woocommerce-mini-cart-item dl dt {
  display: inline;
  font-weight: 600;
  color: var(--color-text);
}

.mini-cart-contents .woocommerce-mini-cart-item dl.variation dd,
.mini-cart-contents .woocommerce-mini-cart-item dl dd {
  display: inline;
  margin: 0;
}

.mini-cart-contents .woocommerce-mini-cart-item dl.variation dd::after,
.mini-cart-contents .woocommerce-mini-cart-item dl dd::after {
  content: '';
  display: block;
}

.mini-cart-contents .woocommerce-mini-cart-item .quantity {
  grid-area: qty;
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--color-text);
  margin-top: 6px;
}

.mini-cart-contents .woocommerce-mini-cart__total {
  display: flex;
  justify-content: space-between;
  padding: 12px 0;
  font-weight: 600;
  border-top: 1px solid var(--color-border);
  margin-top: 8px;
}

.mini-cart-contents .woocommerce-mini-cart__buttons {
  display: flex;
  gap: 8px;
  padding-top: 12px;
}

.mini-cart-contents .woocommerce-mini-cart__buttons a {
  flex: 1;
  text-align: center;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 0.85rem;
  transition: all var(--transition);
}

.mini-cart-contents .woocommerce-mini-cart__buttons .wc-forward:first-child {
  background: var(--color-cream);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}

.mini-cart-contents .woocommerce-mini-cart__buttons .wc-forward:first-child:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.mini-cart-contents .woocommerce-mini-cart__buttons .checkout {
  background: var(--color-primary);
  color: var(--color-white);
}

.mini-cart-contents .woocommerce-mini-cart__buttons .checkout:hover {
  background: var(--color-primary-dark);
}

/* ===== WooCommerce Messages ===== */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  padding: 16px 24px;
  margin-bottom: 24px;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
}

.woocommerce-message {
  background: #d4edda;
  border: 1px solid #c3e6cb;
  color: #155724;
}

.woocommerce-info {
  background: var(--color-primary-light);
  border: 1px solid var(--color-secondary-light);
  color: var(--color-primary-dark);
}

.woocommerce-error {
  background: #f8d7da;
  border: 1px solid #f5c6cb;
  color: #721c24;
  list-style: none;
  padding-left: 24px;
}

/* ===== Product Summary Notices (above Category row) ===== */
.product-notices-area {
  margin-top: 4px;
  margin-bottom: 4px;
}

.product-notices-area:empty {
  display: none;
}

.product-notices-area .woocommerce-message,
.product-notices-area .woocommerce-info,
.product-notices-area .woocommerce-error {
  margin-bottom: 0;
  border-radius: var(--radius-md);
  font-size: 0.88rem;
  display: flex;
  align-items: center;
  gap: 10px;
}

.product-notices-area .woocommerce-message::before {
  content: '\2713';
  font-weight: 700;
  font-size: 1rem;
  flex-shrink: 0;
}

/* Hide the "View cart" button WooCommerce appends inside the notice */
.product-notices-area .woocommerce-message .button.wc-forward {
  display: none;
}

/* ===== WooCommerce Buttons ===== */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  background: var(--color-primary);
  color: var(--color-white);
  font-weight: 600;
  padding: 12px 24px;
  border-radius: var(--radius-sm);
  border: none;
  transition: all var(--transition);
  font-family: var(--font-body);
  font-size: 0.9rem;
  cursor: pointer;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--color-primary-dark);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt {
  background: var(--color-primary);
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: var(--color-primary-dark);
}

/* ===== Mobile Responsive ===== */
@media (max-width: 992px) {
  .shop-layout {
    grid-template-columns: 1fr;
  }

  .shop-layout.sidebar-hidden {
    grid-template-columns: 1fr;
  }

  .shop-sidebar {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 320px;
    max-width: 85vw;
    background: var(--color-white);
    z-index: 1001;
    padding: 24px;
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
  }

  .shop-sidebar.open {
    display: block;
    transform: translateX(0);
  }

  .sidebar-close {
    display: block;
  }

  .page-hero {
    padding: 36px 0 40px;
  }

  .page-hero h1 {
    font-size: 2rem;
  }

  .products-grid.list-view .product-card {
    grid-template-columns: 180px 1fr;
    grid-template-rows: auto auto;
  }

  .products-grid.list-view .product-card-footer {
    grid-column: 1 / -1;
    padding: 0 20px 20px;
  }

  .product-layout {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .product-gallery {
    position: static;
  }

  .product-info h1,
  .product_title {
    font-size: 1.8rem;
  }

  .related-products .products-grid,
  .related.products .products {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  /* â”€â”€ Shop / Archive â”€â”€ */
  .products-grid,
  .products-grid.grid-3-col,
  .products-grid.grid-4-col {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  .category-chips { display: none; }

  .shop-toolbar { flex-direction: column; align-items: stretch; }
  .shop-toolbar-left,
  .shop-toolbar-right { justify-content: space-between; }

  .page-hero { padding: 32px 0 36px; }
  .page-hero h1 { font-size: 1.75rem; }

  /* â”€â”€ Top padding after hero on all page types â”€â”€ */
  .product-detail-section,
  .product-tabs-section,
  .archive-section,
  .woocommerce .container > .shop-toolbar,
  .woocommerce .container > .shop-layout {
    padding-top: 24px;
  }

  .breadcrumb { font-size: 0.82rem; padding: 6px 14px; gap: 8px; }

  .products-grid.list-view .product-card { grid-template-columns: 1fr; }
  .products-grid.list-view .product-card-image { min-height: 200px; }
  .products-grid.list-view .product-card-footer { padding: 0 20px 20px; }

  /* â”€â”€ Single Product â€” Hero Banner â”€â”€ */
  .product-breadcrumb {
    padding: 20px 0 24px;
  }

  .product-hero-title {
    font-size: 1.3rem;
    margin-bottom: 8px;
  }

  .product-hero-subtitle { font-size: 0.82rem; margin-bottom: 12px; }

  .breadcrumb { gap: 6px; font-size: 0.78rem; }

  /* â”€â”€ Single Product â€” Layout â”€â”€ */
  .product-layout {
    gap: 0;
    padding-bottom: 0;
  }

  /* â”€â”€ Gallery â”€â”€ */
  .product-gallery {
    position: static;
    margin: 0;
    padding-top: 20px;
  }

  .product-gallery-main {
    border-radius: var(--radius-md);
    margin-bottom: 8px;
    background: var(--color-cream);
  }

  .product-gallery-main img {
    aspect-ratio: 1;
    object-fit: contain;
    width: 100%;
  }

  .product-thumbnails {
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
    margin-bottom: 0;
  }

  .product-thumbnail {
    border-width: 1.5px;
  }

  /* â”€â”€ Product Info â”€â”€ */
  .product-info {
    padding: 20px 0 0;
  }

  .product-info-category {
    font-size: 0.72rem;
    letter-spacing: 1px;
    margin-bottom: 6px;
  }

  .product-info h1,
  .product_title {
    font-size: 1.5rem;
    margin-bottom: 8px;
    line-height: 1.25;
  }

  .product-price-main {
    font-size: 1.6rem;
  }

  .product-price-block { margin-bottom: 16px; }

  .product-description {
    font-size: 0.9rem;
    line-height: 1.7;
    margin-bottom: 20px;
  }

  /* â”€â”€ Variations / Swatches â”€â”€ */
  .variations_form .variations {
    margin-bottom: 16px;
  }

  .swatch-options,
  .size-options {
    gap: 8px;
  }

  .size-option {
    min-width: 80px;
    padding: 10px 12px;
  }

  /* â”€â”€ Add to Cart Row â”€â”€ */
  .woocommerce-variation-add-to-cart {
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 12px;
  }

  /* Qty stepper â€” consistent height & sizing */
  .product-info .qty-minus,
  .product-info .qty-plus {
    width: 44px;
    height: 48px;
    font-size: 1.2rem;
  }

  .product-info .quantity {
    height: 48px;
  }

  .product-info .quantity input.qty {
    width: 48px;
    height: 48px;
    font-size: 1rem;
  }

  /* ATC button full width below qty */
  .woocommerce-variation-add-to-cart .single_add_to_cart_button,
  .product-info form.cart .single_add_to_cart_button,
  .product-info .single_add_to_cart_button {
    flex: 1;
    min-width: 0;
    height: 44px;
    font-size: 0.92rem;
    padding: 0 20px;
    margin-right: 0;
  }

  /* Wishlist full width */
  .wishlist-btn {
    width: 100%;
    height: 44px;
    border-radius: var(--radius-sm);
    margin-left: 0 !important;
    border: 1px solid var(--color-border);
    background: var(--color-white);
    font-size: 0.88rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
  }

  /* â”€â”€ Addon plugin fields â”€â”€ */
  .wc-pao-addon select {
    font-size: 0.85rem;
    padding: 10px 32px 10px 12px;
  }

  /* â”€â”€ Delivery promises strip â”€â”€ */
  .delivery-promises {
    gap: 10px;
  }

  .delivery-promise {
    font-size: 0.78rem;
    padding: 8px 12px;
  }

  /* â”€â”€ Tabs â”€â”€ */
  .woocommerce-tabs .wc-tabs,
  .product-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .woocommerce-tabs .wc-tabs::-webkit-scrollbar { display: none; }

  .woocommerce-tabs .wc-tabs li a,
  .product-tab {
    padding: 11px 18px;
    white-space: nowrap;
    font-size: 0.85rem;
  }

  .woocommerce-tabs .wc-tabs li {
    flex-shrink: 0;
  }

  .woocommerce-Tabs-panel,
  .tab-content {
    padding: 20px 0;
    font-size: 0.9rem;
  }

  /* â”€â”€ Related products â”€â”€ */
  .related-products .products-grid,
  .related.products .products {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  .related-products,
  .related.products {
    padding: 32px 0;
  }

  /* â”€â”€ Product detail section spacing â”€â”€ */
  .product-detail-section {
    padding: 0 0 100px; /* clearance for sticky ATC bar */
  }

  .product-tabs-section {
    padding-bottom: 24px;
  }

  .related-products .section-header h2 {
    font-size: 1.4rem;
  }

  /* â”€â”€ Mini cart â”€â”€ */
  .mini-cart-dropdown {
    width: 300px;
    right: -40px;
  }
}

@media (max-width: 480px) {
  /* â”€â”€ Archive cards â”€â”€ */
  .products-grid,
  .products-grid.grid-3-col,
  .products-grid.grid-4-col {
    gap: 10px !important;
  }

  .product-card-body { padding: 10px 10px 6px; }
  .product-card-footer { padding: 0 10px 10px; }
  .product-card-title { font-size: 0.85rem; }
  .product-category { font-size: 0.65rem; }
  .add-to-cart-btn { font-size: 0.78rem; padding: 8px 10px; }

  /* â”€â”€ Single product â”€â”€ */
  .product-hero-title { font-size: 1.15rem; }

  .product-info h1,
  .product_title {
    font-size: 1.3rem;
  }

  .product-price-main { font-size: 1.4rem; }

  .product-thumbnails {
    grid-template-columns: repeat(4, 1fr);
    gap: 5px;
  }

  /* Swatches */
  .swatch-options,
  .size-options { gap: 7px; }

  .size-option {
    min-width: 70px;
    padding: 8px 10px;
    font-size: 0.8rem;
  }

  .size-option .size-price { font-size: 0.7rem; }

  /* ATC â€” qty + button stay on one line */
  .woocommerce-variation-add-to-cart .single_add_to_cart_button,
  .product-info form.cart .single_add_to_cart_button,
  .product-info .single_add_to_cart_button {
    font-size: 0.85rem;
    padding: 0 14px;
  }

  /* Mini cart slides up from bottom */
  .mini-cart-dropdown {
    position: fixed;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    border-radius: var(--radius-md) var(--radius-md) 0 0;
  }
}

/* ===== WooCommerce Star Rating ===== */
.star-rating {
  display: inline-flex;
  overflow: hidden;
  position: relative;
  height: 1em;
  line-height: 1;
  font-size: 0.9rem;
  width: 5em;
  font-family: 'star';
}

.star-rating::before {
  content: '\e021\e021\e021\e021\e021';
  color: var(--color-border);
  float: left;
  top: 0;
  left: 0;
  position: absolute;
}

.star-rating span {
  overflow: hidden;
  float: left;
  top: 0;
  left: 0;
  position: absolute;
  padding-top: 1.5em;
}

.star-rating span::before {
  content: '\e020\e020\e020\e020\e020';
  color: var(--color-accent);
  top: 0;
  position: absolute;
  left: 0;
}

/* ===== Sale badge on archive ===== */
.woocommerce span.onsale {
  display: none;
}

/* ===== Wishlist Toast Notification ===== */
.wishlist-toast {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  padding: 10px 16px;
  background: var(--color-cream);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-primary);
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  animation: toastIn 0.25s ease;
}

.wishlist-toast-hide {
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

@keyframes toastIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.wishlist-toast-msg {
  flex: 1;
  color: var(--color-text);
  font-weight: 500;
}

.wishlist-toast-link {
  color: var(--color-primary);
  font-weight: 600;
  white-space: nowrap;
  text-decoration: none;
  transition: color var(--transition);
}

.wishlist-toast-link:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}
/* â”€â”€ Shake animation for swatch options when no size selected â”€â”€ */
@keyframes bf-shake {
  0%,100% { transform: translateX(0); }
  20%      { transform: translateX(-6px); }
  40%      { transform: translateX(6px); }
  60%      { transform: translateX(-4px); }
  80%      { transform: translateX(4px); }
}
.bf-shake { animation: bf-shake 0.45s ease; }

/* ==============================================
   FLOATING CART & CART DRAWER
   ============================================== */

/* --- Floating Trigger Button --- */
.floating-cart {
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 1200;
  transform: translateY(0);
  transition: transform var(--transition), opacity var(--transition);
}

.floating-cart.hidden {
  transform: translateY(100px);
  opacity: 0;
  pointer-events: none;
}

.floating-cart-trigger {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  border: none;
  cursor: pointer;
  box-shadow: 0 6px 24px rgba(27, 20, 100, 0.35), 0 2px 8px rgba(27, 20, 100, 0.2);
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
  outline-offset: 3px;
}

.floating-cart-trigger:hover {
  background: var(--color-primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(27, 20, 100, 0.4), 0 4px 12px rgba(27, 20, 100, 0.25);
}

.floating-cart-trigger:active {
  transform: translateY(0);
  box-shadow: 0 4px 16px rgba(27, 20, 100, 0.3);
}

.floating-cart-trigger:focus-visible {
  outline: 2px solid var(--color-accent);
}

.floating-cart-icon {
  width: 24px;
  height: 24px;
  stroke: var(--color-white);
  stroke-width: 1.75;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.floating-cart-count {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 22px;
  height: 22px;
  padding: 0 5px;
  border-radius: var(--radius-full);
  background: var(--color-accent);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 22px;
  text-align: center;
  box-shadow: 0 2px 6px rgba(201, 169, 110, 0.5);
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1), background var(--transition);
}

.floating-cart-count.bump {
  animation: floatingCartBump 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes floatingCartBump {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.4); }
  100% { transform: scale(1); }
}

/* Hide when cart is empty */
.floating-cart.empty .floating-cart-count {
  display: none;
}

/* --- Cart Drawer Overlay --- */
.cart-drawer {
  position: fixed;
  inset: 0;
  z-index: 1300;
  pointer-events: none;
}

.cart-drawer.open {
  pointer-events: auto;
}

.cart-drawer-overlay {
  position: absolute;
  inset: 0;
  background: var(--color-overlay);
  opacity: 0;
  transition: opacity 0.35s ease;
  backdrop-filter: blur(2px);
}

.cart-drawer.open .cart-drawer-overlay {
  opacity: 1;
}

/* --- Cart Drawer Panel --- */
.cart-drawer-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 420px;
  max-width: 100vw;
  background: var(--color-white);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: -8px 0 40px rgba(27, 20, 100, 0.12);
}

.cart-drawer.open .cart-drawer-panel {
  transform: translateX(0);
}

/* --- Drawer Header --- */
.cart-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 28px 20px;
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
  background: var(--color-cream-dark);
}

.cart-drawer-title {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.01em;
  margin: 0;
}

.cart-drawer-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: transparent;
  border: 1.5px solid var(--color-border);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
  outline-offset: 3px;
}

.cart-drawer-close:hover {
  background: var(--color-primary-light);
  border-color: var(--color-primary);
  transform: rotate(90deg);
}

.cart-drawer-close:focus-visible {
  outline: 2px solid var(--color-accent);
}

.cart-drawer-close svg {
  width: 16px;
  height: 16px;
  stroke: var(--color-text);
  stroke-width: 2;
  stroke-linecap: round;
}

/* --- Drawer Body --- */
.cart-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
}

.cart-drawer-body::-webkit-scrollbar {
  width: 4px;
}

.cart-drawer-body::-webkit-scrollbar-track {
  background: transparent;
}

.cart-drawer-body::-webkit-scrollbar-thumb {
  background: var(--color-border);
  border-radius: 2px;
}

/* --- Override mini-cart-contents inside drawer --- */
.cart-drawer-body .mini-cart-contents {
  padding: 20px 28px;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart__empty-message {
  padding: 48px 0;
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 1rem;
  color: var(--color-text-muted);
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item {
  grid-template-columns: 80px 1fr 24px;
  grid-template-areas:
    "img name    remove"
    "img addons  remove"
    "img qty     remove";
  gap: 0 16px;
  padding: 16px 0;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item > a:not(.remove) {
  grid-area: img;
  grid-row: 1 / span 3;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item img {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-md);
  object-fit: cover;
  border: 1px solid var(--color-border);
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item .remove {
  grid-area: remove;
  grid-row: 1;
  align-self: start;
  text-align: right;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item .bf-cart-item-name {
  grid-area: name;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.4;
  color: var(--color-text);
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item .bf-cart-item-name a {
  color: var(--color-text);
  font-weight: 700;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item dl.variation,
.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item dl {
  grid-area: addons;
  font-size: 0.82rem;
  display: block;
  line-height: 1.7;
  margin-top: 4px;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart-item .quantity {
  grid-area: qty;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-text);
  margin-top: 6px;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart__total {
  font-size: 1rem;
  padding: 16px 0;
  margin-top: 4px;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart__buttons {
  flex-direction: column;
  padding-top: 16px;
  gap: 10px;
}

.cart-drawer-body .mini-cart-contents .woocommerce-mini-cart__buttons a {
  padding: 13px 20px;
  font-size: 0.9rem;
  border-radius: var(--radius-md);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  font-weight: 700;
}

/* --- body lock when drawer open --- */
body.cart-drawer-open {
  overflow: hidden;
}

/* --- Responsive --- */
@media (max-width: 480px) {
  .floating-cart {
    bottom: 20px;
    right: 20px;
  }

  .floating-cart-trigger {
    width: 54px;
    height: 54px;
  }

  .cart-drawer-panel {
    width: 100vw;
  }

  .cart-drawer-header {
    padding: 20px 20px 16px;
  }

  .cart-drawer-body .mini-cart-contents {
    padding: 16px 20px;
  }
}

/* ============================================================
   CHECKOUT PAGE â€” Bulldog Flowers Premium Experience
   Flexible Checkout Fields Pro + WooCommerce classic checkout
   ============================================================ */

/* ---------- Page Layout ---------- */
.woocommerce-checkout .entry-content,
body.woocommerce-checkout .site-main {
  background: var(--color-cream);
}

.woocommerce-checkout #wc_checkout_add_ons,
.woocommerce-checkout .woocommerce {
  max-width: 1160px;
  margin: 0 auto;
  padding: 48px 24px 64px;
}

/* Two-column grid: fields left, order summary right */
.woocommerce-checkout form.woocommerce-checkout {
  display: grid;
  grid-template-columns: 1fr 420px;
  grid-template-rows: auto;
  column-gap: 36px;
  row-gap: 0;
  align-items: start;
}

/* Column placement */
.woocommerce-checkout form.woocommerce-checkout #customer_details {
  grid-column: 1;
  grid-row: 1;
}

.woocommerce-checkout form.woocommerce-checkout #order_review_heading {
  grid-column: 2;
  grid-row: 1;
}

.woocommerce-checkout form.woocommerce-checkout #order_review {
  grid-column: 2;
  grid-row: 1 / span 3;
  position: sticky;
  top: 110px;
}

/* ---------- Checkout page hero ---------- */
.woocommerce-checkout .page-hero {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-secondary-dark) 55%, var(--color-secondary) 100%);
  padding: 40px 0 44px;
}

/* ---------- Section Cards ---------- */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout .woocommerce-additional-fields,
.woocommerce-checkout #payment {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 32px;
  margin-bottom: 24px;
  border: 1px solid var(--color-border);
  transition: box-shadow var(--transition);
}

.woocommerce-checkout .woocommerce-billing-fields:hover,
.woocommerce-checkout .woocommerce-shipping-fields:hover,
.woocommerce-checkout .woocommerce-additional-fields:hover,
.woocommerce-checkout #payment:hover {
  box-shadow: var(--shadow-hover);
}

/* ---------- Section Headings ---------- */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #payment h3,
.woocommerce-checkout .bf-delivery-heading {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--color-cream-dark);
  display: flex;
  align-items: center;
  gap: 10px;
}

.woocommerce-checkout .woocommerce-billing-fields h3::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 22px;
  background: linear-gradient(180deg, var(--color-accent), var(--color-secondary));
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.woocommerce-checkout .woocommerce-shipping-fields h3::before,
.woocommerce-checkout .woocommerce-shipping-fields > h3::before,
.woocommerce-checkout .shipping_address > h3::before,
.woocommerce-checkout .bf-delivery-heading::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 22px;
  background: linear-gradient(180deg, var(--color-accent), var(--color-secondary));
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

/* Shipping section heading â€” matches Billing information exactly */
.woocommerce-checkout .woocommerce-shipping-fields > h3,
.woocommerce-checkout .shipping_address > h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--color-cream-dark);
  display: flex;
  align-items: center;
  gap: 10px;
}

.woocommerce-checkout .woocommerce-additional-fields h3::before,
.woocommerce-checkout #payment h3::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 22px;
  background: linear-gradient(180deg, var(--color-primary), var(--color-accent));
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

/* ---------- Form Fields Layout ---------- */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .woocommerce-additional-fields__field-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 16px;
  row-gap: 0;
}

/* Full-width fields */
.woocommerce-checkout .form-row.form-row-wide,
.woocommerce-checkout .form-row.notes,
.woocommerce-checkout p.form-row-wide {
  grid-column: 1 / -1;
}

/* Half-width fields */
.woocommerce-checkout .form-row.form-row-first {
  grid-column: 1;
}
.woocommerce-checkout .form-row.form-row-last {
  grid-column: 2;
}

/* ---------- Labels ---------- */
.woocommerce-checkout .form-row label,
.woocommerce-checkout .woocommerce-form__label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-text);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 7px;
  display: block;
}

.woocommerce-checkout .form-row label .required,
.woocommerce-checkout label abbr[title] {
  color: #C0392B;
  font-size: 1rem;
  margin-left: 2px;
  text-decoration: none;
  border: none;
}

/* ---------- Inputs, Selects, Textareas ---------- */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .select2-container--default .select2-selection--single,
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout input[type="password"] {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 0.93rem;
  color: var(--color-text);
  background: var(--color-cream);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
  appearance: none;
  outline: none;
  line-height: 1.5;
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout input[type="text"]:focus,
.woocommerce-checkout input[type="email"]:focus,
.woocommerce-checkout input[type="tel"]:focus,
.woocommerce-checkout input[type="number"]:focus,
.woocommerce-checkout input[type="password"]:focus {
  border-color: var(--color-secondary);
  background: var(--color-white);
  box-shadow: 0 0 0 3px rgba(107, 91, 149, 0.12);
}

.woocommerce-checkout .form-row textarea {
  min-height: 110px;
  resize: vertical;
}

/* Select2 styling */
.woocommerce-checkout .select2-container--default .select2-selection--single {
  height: auto;
  line-height: 1.5;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--color-text);
  padding: 0;
  line-height: 1.5;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100%;
  top: 0;
  right: 12px;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: var(--color-text-muted) transparent transparent;
}

.select2-dropdown {
  border-color: var(--color-secondary) !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: var(--shadow-lg) !important;
  font-family: var(--font-body);
  font-size: 0.93rem;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: var(--color-primary) !important;
}

/* ---------- Flexible Checkout Fields Pro fields ---------- */
.woocommerce-checkout .fcf-field,
.woocommerce-checkout [id*="fcf"],
.woocommerce-checkout .wcf-field {
  margin-bottom: 20px;
}

/* Radio / Checkbox groups from FCF Pro */
.woocommerce-checkout .form-row .woocommerce-input-wrapper input[type="radio"],
.woocommerce-checkout .form-row .woocommerce-input-wrapper input[type="checkbox"] {
  accent-color: var(--color-primary);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* Date / Time pickers from FCF Pro */
.woocommerce-checkout .form-row input[type="date"],
.woocommerce-checkout .form-row input[type="time"] {
  width: 100%;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 0.93rem;
  color: var(--color-text);
  background: var(--color-cream);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}

.woocommerce-checkout .form-row input[type="date"]:focus,
.woocommerce-checkout .form-row input[type="time"]:focus {
  border-color: var(--color-secondary);
  background: var(--color-white);
  box-shadow: 0 0 0 3px rgba(107, 91, 149, 0.12);
}

/* ---------- Field Validation States ---------- */
.woocommerce-checkout .form-row.woocommerce-validated .woocommerce-input-wrapper::after,
.woocommerce-checkout .form-row.woocommerce-validated input.input-text {
  border-color: #27ae60;
}

.woocommerce-checkout .form-row.woocommerce-invalid input.input-text,
.woocommerce-checkout .form-row.woocommerce-invalid select,
.woocommerce-checkout .form-row.woocommerce-invalid .select2-selection {
  border-color: #C0392B;
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.1);
}

/* ---------- Shipping Toggle â€” hidden, fields always visible ---------- */
.woocommerce-checkout #ship-to-different-address {
  display: none;
}

/* Force shipping fields block to always be visible */
.woocommerce-checkout .woocommerce-shipping-fields #ship-to-different-address-checkbox {
  display: none;
}

.woocommerce-checkout .shipping_address {
  display: block !important;
}

/* ---------- Order Review (Right Column) ---------- */
.woocommerce-checkout #order_review_heading {
  background: var(--color-white);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  border: 1px solid var(--color-border);
  border-bottom: none;
  padding: 28px 28px 0;
  margin-bottom: 0;
  font-size: 1.15rem;
}

.woocommerce-checkout #order_review {
  background: var(--color-white);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  border: 1px solid var(--color-border);
  border-top: none;
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

/* Order review table */
.woocommerce-checkout #order_review .woocommerce-checkout-review-order-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table thead th {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--color-text-muted);
  padding: 16px 28px 12px;
  border-bottom: 1px solid var(--color-border);
  text-align: left;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table thead th:last-child {
  text-align: right;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table tbody .cart_item td {
  padding: 14px 28px;
  border-bottom: 1px solid var(--color-cream-dark);
  vertical-align: middle;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table tbody .cart_item .product-name {
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.4;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table tbody .cart_item .product-name .product-quantity {
  color: var(--color-text-muted);
  font-weight: 400;
  font-size: 0.85rem;
  display: block;
  margin-top: 2px;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table tbody .cart_item .product-total {
  text-align: right;
  font-weight: 600;
  color: var(--color-primary);
}

/* Order totals */
.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr td,
.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr th {
  padding: 12px 28px;
  border-bottom: 1px solid var(--color-cream-dark);
  font-size: 0.88rem;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot .order-total td,
.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot .order-total th {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-white);
  padding-top: 18px;
  padding-bottom: 18px;
  border-bottom: none;
  border-top: none;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary-dark) 100%);
  letter-spacing: 0.01em;
}

/* Total amount value â€” extra emphasis */
.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot .order-total td {
  color: var(--color-white);
  font-size: 1.25rem;
}

/* Shipping methods */
.woocommerce-checkout #order_review .shipping th,
.woocommerce-checkout #order_review .shipping td {
  padding: 12px 28px;
}

.woocommerce-checkout .woocommerce-shipping-methods {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.woocommerce-checkout .woocommerce-shipping-methods li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  transition: border-color var(--transition), background var(--transition);
  cursor: pointer;
}

.woocommerce-checkout .woocommerce-shipping-methods li:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}

.woocommerce-checkout .woocommerce-shipping-methods li input[type="radio"] {
  accent-color: var(--color-primary);
}

.woocommerce-checkout .woocommerce-shipping-methods li label {
  font-size: 0.9rem;
  font-weight: 500;
  margin: 0;
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
}

/* ---------- Payment Methods ---------- */
.woocommerce-checkout #payment {
  margin-bottom: 0;
}

.woocommerce-checkout #payment .wc_payment_methods {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}

.woocommerce-checkout #payment .wc_payment_method {
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.woocommerce-checkout #payment .wc_payment_method:has(input:checked) {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(27, 20, 100, 0.08);
}

.woocommerce-checkout #payment .wc_payment_method label {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  cursor: pointer;
  margin: 0;
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.93rem;
  font-weight: 500;
  color: var(--color-text);
}

.woocommerce-checkout #payment .wc_payment_method label img {
  max-height: 24px;
  width: auto;
  max-width: 60px;
  object-fit: contain;
}

.woocommerce-checkout #payment .wc_payment_method input[type="radio"] {
  accent-color: var(--color-primary);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.woocommerce-checkout #payment .payment_box {
  background: var(--color-cream);
  padding: 14px 18px;
  border-top: 1px solid var(--color-border);
  font-size: 0.88rem;
  color: var(--color-text-light);
}

.woocommerce-checkout #payment .payment_box p {
  margin: 0;
}

/* Privacy / terms notice */
.woocommerce-checkout #payment .woocommerce-terms-and-conditions-wrapper {
  margin-top: 16px;
}

.woocommerce-checkout #payment .woocommerce-privacy-policy-text {
  font-size: 0.82rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

.woocommerce-checkout #payment .woocommerce-privacy-policy-text a {
  color: var(--color-secondary);
  font-weight: 500;
  text-decoration: underline;
}

/* ---------- Place Order Button ---------- */
.woocommerce-checkout #payment #place_order,
.woocommerce-checkout .woocommerce-checkout-payment #place_order {
  width: 100%;
  padding: 16px 32px;
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--color-white);
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary-dark) 100%);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition), opacity var(--transition);
  position: relative;
  overflow: hidden;
  margin-top: 20px;
  box-shadow: 0 4px 16px rgba(27, 20, 100, 0.28);
}

.woocommerce-checkout #payment #place_order::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(201, 169, 110, 0.18) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--transition);
}

.woocommerce-checkout #payment #place_order:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(27, 20, 100, 0.35);
}

.woocommerce-checkout #payment #place_order:hover::before {
  opacity: 1;
}

.woocommerce-checkout #payment #place_order:active {
  transform: translateY(0);
}

/* Secure checkout badge under button */
.woocommerce-checkout #payment .place-order::after {
  content: 'ðŸ”’ Secure Checkout â€” Your data is encrypted';
  display: block;
  text-align: center;
  font-size: 0.78rem;
  color: var(--color-text-muted);
  margin-top: 10px;
  letter-spacing: 0.02em;
}

/* ---------- Return to Cart Link ---------- */
.woocommerce-checkout .return-to-cart,
.woocommerce-checkout a.cart-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--color-text-muted);
  font-weight: 500;
  margin-top: 12px;
  transition: color var(--transition);
}

.woocommerce-checkout .return-to-cart:hover,
.woocommerce-checkout a.cart-back:hover {
  color: var(--color-primary);
}

/* ---------- Coupon / Promo ---------- */
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
  background: linear-gradient(90deg, var(--color-primary-light) 0%, var(--color-cream) 100%);
  border: 1px solid var(--color-secondary-light);
  border-radius: var(--radius-sm);
  padding: 12px 20px;
  font-size: 0.88rem;
  color: var(--color-primary-dark);
  margin-bottom: 20px;
}

.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a {
  color: var(--color-secondary);
  font-weight: 600;
  text-decoration: underline;
}

.woocommerce-checkout .woocommerce-form-coupon {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 24px;
  margin-bottom: 24px;
  display: flex;
  gap: 12px;
  align-items: flex-end;
}

.woocommerce-checkout .woocommerce-form-coupon .form-row {
  flex: 1;
  margin: 0;
}

.woocommerce-checkout .woocommerce-form-coupon .form-row-last {
  flex: 0 0 auto;
}

.woocommerce-checkout .woocommerce-form-coupon button[name="apply_coupon"] {
  padding: 12px 24px;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition);
  white-space: nowrap;
}

.woocommerce-checkout .woocommerce-form-coupon button[name="apply_coupon"]:hover {
  background: var(--color-primary-dark);
}

/* ---------- Login Prompt ---------- */
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info {
  background: var(--color-primary-light);
  border: 1px solid var(--color-secondary-light);
  border-radius: var(--radius-sm);
  padding: 12px 20px;
  font-size: 0.88rem;
  color: var(--color-primary-dark);
  margin-bottom: 20px;
}

.woocommerce-checkout .woocommerce-form-login {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 28px;
  margin-bottom: 24px;
}

/* ---------- Progress / Trust Indicators ---------- */
.woocommerce-checkout .checkout-trust-bar {
  display: flex;
  justify-content: center;
  gap: 32px;
  padding: 16px 24px;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: 28px;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-text-light);
}

.woocommerce-checkout .checkout-trust-bar span {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ---------- Order Received / Thank You Page ---------- */
.woocommerce-order-received .woocommerce-order {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: 40px;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
}

.woocommerce-order-received .woocommerce-thankyou-order-received {
  font-family: var(--font-heading);
  font-size: 1.8rem;
  color: var(--color-primary);
  margin-bottom: 12px;
}

.woocommerce-order-received .woocommerce-order-details,
.woocommerce-order-received .woocommerce-customer-details {
  margin-top: 32px;
}

/* ---------- Notices on Checkout ---------- */
.woocommerce-checkout .woocommerce-NoticeGroup .woocommerce-error {
  border-radius: var(--radius-md);
  padding: 16px 24px;
  margin-bottom: 24px;
  font-size: 0.9rem;
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .woocommerce-checkout form.woocommerce-checkout {
    grid-template-columns: 1fr 360px;
    column-gap: 24px;
  }
}

@media (max-width: 768px) {
  .woocommerce-checkout .woocommerce {
    padding: 24px 16px 48px;
  }

  .woocommerce-checkout form.woocommerce-checkout {
    grid-template-columns: 1fr;
  }

  .woocommerce-checkout form.woocommerce-checkout #customer_details {
    grid-column: 1;
    grid-row: 1;
  }

  .woocommerce-checkout form.woocommerce-checkout .woocommerce-additional-fields {
    grid-column: 1;
    grid-row: 2;
  }

  .woocommerce-checkout form.woocommerce-checkout #order_review_heading {
    grid-column: 1;
    grid-row: 3;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  }

  .woocommerce-checkout form.woocommerce-checkout #order_review {
    grid-column: 1;
    grid-row: 4;
    position: static;
  }

  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
    grid-template-columns: 1fr;
  }

  .woocommerce-checkout .form-row.form-row-first,
  .woocommerce-checkout .form-row.form-row-last {
    grid-column: 1;
  }

  .woocommerce-checkout .woocommerce-billing-fields,
  .woocommerce-checkout .woocommerce-shipping-fields,
  .woocommerce-checkout .woocommerce-additional-fields,
  .woocommerce-checkout #payment {
    padding: 22px 18px;
  }

  .woocommerce-checkout .woocommerce-form-coupon {
    flex-direction: column;
  }

  .woocommerce-checkout .checkout-trust-bar {
    flex-wrap: wrap;
    gap: 14px;
    justify-content: flex-start;
  }
}

@media (max-width: 480px) {
  .woocommerce-checkout .woocommerce-checkout-review-order-table thead th,
  .woocommerce-checkout .woocommerce-checkout-review-order-table tbody .cart_item td,
  .woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr td,
  .woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr th,
  .woocommerce-checkout .woocommerce-checkout-review-order-table tfoot .order-total td,
  .woocommerce-checkout .woocommerce-checkout-review-order-table tfoot .order-total th {
    padding-left: 16px;
    padding-right: 16px;
  }
}

/* ============================================================
   END CHECKOUT STYLES
   ============================================================ */


/* â”€â”€ Cart Page: Proceed to Checkout button â”€â”€ */
.wc-block-cart__submit-button,
.wc-block-cart__submit .wc-block-cart__submit-button {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary-dark) 100%);
  color: var(--color-white);
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  border: none;
  border-radius: var(--radius-md);
  box-shadow: 0 4px 16px rgba(27, 20, 100, 0.28);
  transition: transform var(--transition), box-shadow var(--transition);
  cursor: pointer;
}

.wc-block-cart__submit-button:hover,
.wc-block-cart__submit .wc-block-cart__submit-button:hover {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-secondary-dark) 100%);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(27, 20, 100, 0.36);
}

.wc-block-cart__submit-button:active,
.wc-block-cart__submit .wc-block-cart__submit-button:active {
  transform: translateY(0);
  box-shadow: 0 4px 16px rgba(27, 20, 100, 0.28);
}