/* ==========================================================================
   WooCommerce Custom Stylesheet (Competitor Layout Overrides)
   ========================================================================== */

/* Single Product Layout */
@media (min-width: 769px) {
  .woocommerce div.product {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 48px;
    margin-top: 24px;
  }
  
  .woocommerce div.product div.images {
    width: 100% !important;
    float: none !important;
    margin-bottom: 0 !important;
  }
  
  .woocommerce div.product div.summary {
    width: 100% !important;
    float: none !important;
    margin-bottom: 0 !important;
  }
}

/* Vertical Gallery Style overrides */
.woocommerce div.product div.images .flex-control-thumbs {
  display: flex;
  flex-direction: column;
  position: absolute;
  left: 0;
  top: 0;
  margin: 0;
  padding: 0;
  width: 70px !important;
  z-index: 5;
  gap: 8px;
}

.woocommerce div.product div.images .flex-viewport {
  margin-left: 85px !important; /* Push main viewport right of vertical thumbs */
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.woocommerce div.product div.images .flex-control-thumbs li {
  width: 100% !important;
  float: none !important;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  cursor: pointer;
  background-color: var(--color-bg-white);
}

.woocommerce div.product div.images .flex-control-thumbs li img {
  opacity: 0.6;
  transition: var(--transition-fast);
}

.woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs li img:hover {
  opacity: 1;
}

/* Product Meta & Title */
.woocommerce div.product .product_title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  margin-bottom: 12px;
  color: var(--color-text-dark);
}

.woocommerce div.product .price {
  font-family: var(--font-heading);
  font-size: 1.5rem !important;
  color: var(--color-text-dark) !important;
  margin-bottom: 24px;
}

.woocommerce div.product .price del {
  color: var(--color-text-light);
  font-size: 1.15rem;
  margin-right: 8px;
}

.woocommerce div.product .price ins {
  text-decoration: none;
  font-weight: 700;
  color: var(--color-blue);
}

/* Hide WooCommerce native variations dropdowns (we render custom swatches instead via JS) */
.woocommerce div.product form.cart .variations select {
  display: none !important;
}

/* Custom Swatches Wrapper */
.swatch-group {
  margin-bottom: 24px;
}

.swatch-label {
  display: block;
  font-weight: 700;
  margin-bottom: 10px;
  text-transform: uppercase;
  font-size: 0.8rem;
  letter-spacing: 1px;
  color: var(--color-text-dark);
}

/* Size Swatch Circles */
.swatch-size-container {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.swatch-size-item {
  width: 44px;
  height: 44px;
  border: 1.5px solid var(--color-border);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  transition: var(--transition-fast);
  background-color: var(--color-bg-white);
  color: var(--color-text-dark);
}

.swatch-size-item:hover {
  border-color: var(--color-border-focus);
  background-color: var(--color-bg-gray);
}

.swatch-size-item.selected {
  border-color: var(--color-text-dark);
  background-color: var(--color-primary);
  color: var(--color-bg-white);
  box-shadow: var(--shadow-sm);
}

/* Color Swatch Pills */
.swatch-color-container {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.swatch-color-item {
  padding: 8px 18px;
  border: 1.5px solid var(--color-border);
  border-radius: 50px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 0.85rem;
  cursor: pointer;
  transition: var(--transition-fast);
  background-color: var(--color-bg-white);
}

.swatch-color-item::before {
  content: '';
  width: 14px;
  height: 14px;
  border-radius: 50%;
  display: inline-block;
  border: 1px solid rgba(0,0,0,0.1);
}

/* Specific colors styling */
.swatch-color-item[data-value*="black"]::before { background-color: #000000; }
.swatch-color-item[data-value*="beige"]::before { background-color: #f5f5dc; }
.swatch-color-item[data-value*="grey"]::before { background-color: #808080; }
.swatch-color-item[data-value*="blue"]::before { background-color: #0052cc; }

.swatch-color-item:hover {
  border-color: var(--color-border-focus);
}

.swatch-color-item.selected {
  border-color: var(--color-primary);
  background-color: #f1f5f9;
  box-shadow: var(--shadow-sm);
}

/* Size Chart Link helper */
.swatch-size-chart-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--color-blue);
  text-transform: uppercase;
  margin-bottom: 12px;
  cursor: pointer;
}
.swatch-size-chart-link:hover {
  color: var(--color-blue-hover);
}

/* WooCommerce Cart Forms & Buttons Customization */
.woocommerce div.product form.cart {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 28px;
}

.woocommerce div.product form.cart .quantity {
  margin: 0 !important;
}

.woocommerce div.product form.cart .quantity input.qty {
  width: 80px !important;
  height: 48px;
  padding: 0 10px;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--border-radius-sm);
  font-weight: 700;
}

/* Actions grid: Add to Cart, Buy Now, Wishlist */
.product-actions-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.woocommerce div.product form.cart .button.single_add_to_cart_button {
  background-color: var(--color-text-dark) !important;
  color: var(--color-bg-white) !important;
  height: 48px;
  font-weight: 700;
  font-size: 1rem;
  border-radius: var(--border-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
}

.woocommerce div.product form.cart .button.single_add_to_cart_button:hover {
  background-color: #000000 !important;
}

.btn-buy-now {
  background-color: #581c47; /* Plum color matching competitor */
  color: var(--color-bg-white);
  height: 48px;
  font-weight: 700;
  font-size: 1rem;
  border-radius: var(--border-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition-fast);
}

.btn-buy-now:hover {
  background-color: #401032;
}

/* Shipping Notices Card */
.product-shipping-badges {
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: 16px 20px;
  margin: 32px 0 20px;
}

.shipping-badge-item {
  font-size: 0.85rem;
  margin-bottom: 10px;
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  gap: 10px;
}

.shipping-badge-item:last-child {
  margin-bottom: 0;
}

.shipping-badge-item i {
  font-size: 1rem;
  width: 20px;
}

.text-teal { color: var(--color-teal); }

/* Promo Box card */
.product-promo-card {
  background-color: #faf5ff; /* Soft lavender */
  border: 1px dashed #d8b4fe;
  border-radius: var(--border-radius-sm);
  padding: 16px;
  margin-bottom: 24px;
  display: flex;
  gap: 16px;
  align-items: center;
}

.product-promo-card .promo-icon {
  font-size: 1.5rem;
  color: #7c3aed;
}

.product-promo-card h4 {
  font-size: 0.85rem;
  font-weight: 800;
  color: #7c3aed;
  margin-bottom: 2px;
}

.product-promo-card p {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin-bottom: 0;
}

/* Payment Gateway and Certifications Badge */
.product-payment-gateways {
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 24px;
  margin-bottom: 24px;
}

.product-payment-gateways .payment-title {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--color-text-light);
  margin-bottom: 10px;
}

.payment-icons-flex {
  display: flex;
  gap: 16px;
  align-items: center;
  font-size: 1.5rem;
  color: var(--color-text-light);
  margin-bottom: 12px;
}

.certifications-badges {
  font-size: 0.8rem;
  color: var(--color-text-light);
}

/* Competitor style trust pillars list */
.product-brand-pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 28px;
  margin-bottom: 32px;
  text-align: center;
}

.pillar-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.pillar-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-white);
  color: var(--color-text-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
}

.pillar-item span {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-text-muted);
}

/* Description & Specification Collapsible Accordions */
.product-accordions-group {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 32px;
}

.product-accordion-item {
  background-color: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}

.product-accordion-trigger {
  width: 100%;
  text-align: left;
  padding: 16px 20px;
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--color-text-dark);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: var(--color-bg-white);
  cursor: pointer;
}

.product-accordion-trigger .acc-icon {
  font-size: 0.85rem;
  transition: var(--transition-normal);
}

.product-accordion-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-normal) ease;
}

.product-accordion-content {
  padding: 0 20px 20px;
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

.product-accordion-content ul {
  list-style: disc;
  padding-left: 20px;
}

.product-accordion-content li {
  margin-bottom: 8px;
}

.product-accordion-item.active .acc-icon {
  transform: rotate(180deg);
}

.specs-table {
  width: 100%;
  border-collapse: collapse;
}

.specs-table th, .specs-table td {
  padding: 8px 0;
  text-align: left;
  border-bottom: 1px solid var(--color-bg-gray);
}

.specs-table th {
  font-weight: 700;
  width: 40%;
  color: var(--color-text-dark);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .product-actions-wrapper {
    grid-template-columns: 1fr;
  }
  
  .woocommerce div.product div.images .flex-viewport {
    margin-left: 0 !important;
  }
  
  .woocommerce div.product div.images .flex-control-thumbs {
    position: static;
    flex-direction: row;
    width: 100% !important;
    margin-top: 12px;
    overflow-x: auto;
  }
  
  .woocommerce div.product div.images .flex-control-thumbs li {
    width: 70px !important;
    flex-shrink: 0;
  }
}
