/* =========================================================
   RLM Product Detail Page (PDP) - Refined Design System

   PURPOSE: Lightweight custom PDP template styling
   SCOPE: Products using new template (.rlm-pdp)
   REPLACES: Elementor PDP templates (5.99MB → 0.8MB)

   Design System: Uses design tokens from rlm-design-tokens.css
   Responsive: Mobile-first with progressive enhancement
   Performance: CLS prevention with reserved space
   ========================================================= */

/* ==========================================================================
   CONTAINER & LAYOUT
   ========================================================================== */

/**
 * PDP main container
 * - Follows theme container constraints
 * - Uses design system spacing
 * - Prevents horizontal overflow
 */
.rlm-pdp {
  display: grid;
  gap: var(--space-6);
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

/* Larger screens get more breathing room */
@media (min-width: 1024px) {
  .rlm-pdp {
    gap: var(--space-6);
    padding-left: 0;
    padding-right: 0;
  }
}

/**
 * PDP grid layout - Progressive enhancement
 * Mobile:  Single column (gallery → info)
 * Tablet:  Two columns 60/40 (better than 50/50)
 * Desktop: Two columns 55/45 optimized for content
 */
.rlm-pdp__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  align-items: start;
  min-width: 0; /* Allow grid items to shrink */
  width: 100%;
}

/* Tablet: Two columns with gallery taking more space */
@media (min-width: 768px) {
  .rlm-pdp__grid {
    grid-template-columns: 1.2fr 0.8fr;
    gap: var(--space-6);
  }
}

/* Desktop: Optimized ratio for larger screens */
@media (min-width: 1200px) {
  .rlm-pdp__grid {
    grid-template-columns: 1.1fr 0.9fr;
    gap: var(--space-6);
  }
}

/* ==========================================================================
   GALLERY SECTION
   ========================================================================== */

/**
 * Product gallery
 * - Sticky on desktop for better UX (stays visible while scrolling info)
 * - Prevents CLS with min-height
 * - Contains all images within bounds
 * - Subtle card styling for visual separation
 */
.rlm-pdp__gallery {
  width: 100%;
  max-width: 100%;
  position: relative;
}

/* Sticky gallery on desktop only (not mobile/tablet) */
@media (min-width: 1024px) {
  .rlm-pdp__gallery {
    position: sticky;
    top: var(--space-4);
  }
}

/* Sale badge - pill styling with absolute positioning */
.rlm-pdp__gallery .onsale {
  position: absolute !important;
  top: var(--space-3) !important;
  left: var(--space-3) !important;
  z-index: 10;
  margin: 0 !important;

  /* Pill styling from design system */
  display: inline-flex !important;
  align-items: center !important;
  padding: var(--space-1) var(--space-3) calc(var(--space-1) + 1px) !important;
  border-radius: var(--radius-pill) !important;
  font: var(--font-weight-semibold) var(--fs-small)/1 var(--font-sans) !important;

  /* Red background with white text */
  background: var(--color-danger) !important;
  color: white !important;
  border: none !important;

  /* Subtle elevation */
  box-shadow: var(--shadow-sm) !important;
}

/* WooCommerce gallery container - CLS prevention */
.rlm-pdp__gallery .woocommerce-product-gallery {
  min-height: 300px; /* Reserve space to prevent layout shift */
  width: 100%;
  max-width: 100%;
}

@media (min-width: 768px) {
  .rlm-pdp__gallery .woocommerce-product-gallery {
    min-height: 400px;
  }
}

/* Gallery wrapper - intrinsic sizing */
/* No styles needed - let FlexSlider control dimensions entirely */

/* Main image container (FlexSlider viewport) - card styling */
.rlm-pdp__gallery .flex-viewport {
  background: var(--color-surface);
  border-radius: var(--radius-card);
  border: var(--border-width-1) solid var(--color-border);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  margin-bottom: var(--space-4); /* Space between main image and thumbnails */
}

/* Individual gallery images */
.rlm-pdp__gallery .woocommerce-product-gallery__image {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

/* Image element - preserve aspect ratio with industry-standard height constraints */
.rlm-pdp__gallery .woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  max-height: 450px; /* Mobile: prevent tall images from dominating viewport */
  display: block;
  object-fit: contain;
  max-width: 100%;
}

/* Thumbnails container */
.rlm-pdp__gallery .flex-control-nav.flex-control-thumbs {
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* Individual thumbnails */
.rlm-pdp__gallery .flex-control-nav.flex-control-thumbs li {
  flex: 0 0 calc(25% - var(--space-2));
  max-width: calc(25% - var(--space-2));
  margin: 0;
  list-style: none;
}

/* Thumbnail images */
.rlm-pdp__gallery .flex-control-nav.flex-control-thumbs li img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-md);
  border: 2px solid var(--color-border);
  cursor: pointer;
  transition: border-color var(--duration-150) var(--ease-standard);
}

/* Active thumbnail */
.rlm-pdp__gallery .flex-control-nav.flex-control-thumbs li img.flex-active {
  border-color: var(--color-primary);
}

/* Thumbnail hover */
.rlm-pdp__gallery .flex-control-nav.flex-control-thumbs li:hover img {
  border-color: var(--color-primary);
  opacity: 0.8;
}

@media (min-width: 768px) {
  .rlm-pdp__gallery .woocommerce-product-gallery__image img {
    max-height: 700px; /* Desktop: industry standard ~600-800px */
  }
}

/* Gallery thumbnails */
.rlm-pdp__gallery .flex-control-thumbs {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
  padding: 0;
  list-style: none;
  flex-wrap: wrap;
}

.rlm-pdp__gallery .flex-control-thumbs li {
  flex: 0 0 calc(25% - var(--space-2));
  max-width: calc(25% - var(--space-2));
}

.rlm-pdp__gallery .flex-control-thumbs li img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-md);
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color var(--duration-150) var(--ease-standard);
}

.rlm-pdp__gallery .flex-control-thumbs li img:hover,
.rlm-pdp__gallery .flex-control-thumbs li.flex-active-slide img {
  border-color: var(--color-primary);
}

/* ==========================================================================
   PRODUCT INFO SECTION
   ========================================================================== */

/**
 * Product summary (right column)
 * - Vertical stack with consistent spacing
 * - Design system typography
 * - CLS prevention with min-heights
 */
.rlm-pdp__summary {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  width: 100%;
  max-width: 100%;
}

/* Remove top/bottom margins from all direct children (parent uses gap) */
.rlm-pdp__summary > * {
  margin-top: 0;
  margin-bottom: 0;
}

/* Product title - CLS prevention */
.rlm-pdp__summary .product_title {
  font: var(--font-weight-bold) var(--fs-h3)/var(--lh-tight) var(--font-sans);
  color: var(--color-heading);
  margin: 0; /* No margin - parent uses gap */
  min-height: 2.5em; /* Reserve space for 2 lines */
}

/* Rating */
.rlm-pdp__summary .woocommerce-product-rating {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin: 0; /* No margin - parent uses gap */
}

/* Price - CLS prevention */
.rlm-pdp__summary .price {
  font-size: var(--fs-h3);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  margin: 0; /* No margin - parent uses gap */
  min-height: 1.5em; /* Prevent shift when price loads */
}

.rlm-pdp__summary .price del {
  color: var(--gray-500);
  font-size: var(--fs-h4);
  font-weight: var(--font-weight-normal);
  margin-right: var(--space-2);
}

.rlm-pdp__summary .price ins {
  text-decoration: none;
}

/* Stock status badge */
.rlm-pdp__summary .stock {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-pill);
  font: var(--font-weight-medium) var(--fs-small)/1 var(--font-sans);
  margin: 0; /* No margin - parent uses gap */
  min-height: 32px; /* CLS prevention */
  width: fit-content;
}

/* In stock - green badge */
.rlm-pdp__summary .stock.in-stock {
  background: color-mix(in oklab, var(--color-success), #fff 88%);
  color: var(--color-success);
  border: 1px solid color-mix(in oklab, var(--color-success), #fff 70%);
}

/* Fallback for older browsers */
@supports not (color: color-mix(in oklab, red, blue)) {
  .rlm-pdp__summary .stock.in-stock {
    background: #e6f4ea;
    color: #137333;
    border: 1px solid #b3e0c7;
  }
}

/* Out of stock - red badge */
.rlm-pdp__summary .stock.out-of-stock {
  background: color-mix(in oklab, var(--color-danger), #fff 88%);
  color: var(--color-danger);
  border: 1px solid color-mix(in oklab, var(--color-danger), #fff 70%);
}

/* Fallback for older browsers */
@supports not (color: color-mix(in oklab, red, blue)) {
  .rlm-pdp__summary .stock.out-of-stock {
    background: #fce8e6;
    color: #c5221f;
    border: 1px solid #f4c7c3;
  }
}

/* Short description */
.rlm-pdp__summary .woocommerce-product-details__short-description {
  color: var(--color-text);
  font: var(--font-weight-regular) var(--fs-body)/var(--lh-relaxed) var(--font-sans);
  margin: 0; /* No margin - parent uses gap */
}

.rlm-pdp__summary .woocommerce-product-details__short-description p {
  margin-bottom: var(--space-3);
}

.rlm-pdp__summary .woocommerce-product-details__short-description p:last-child {
  margin-bottom: 0;
}

/* ==========================================================================
   ADD TO CART FORM
   ========================================================================== */

/**
 * Add to cart section
 * - Responsive layout (stacks on mobile)
 * - Design system form controls
 * - Proper button sizing
 */
.rlm-pdp__summary .cart {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: flex-start;
  margin: 0; /* No margin - parent uses gap */
}

/* Quantity selector */
.rlm-pdp__summary .quantity {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.rlm-pdp__summary .quantity label {
  font: var(--font-weight-medium) var(--fs-body)/1 var(--font-sans);
  color: var(--color-text);
}

.rlm-pdp__summary .quantity input[type="number"] {
  width: 80px;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-input);
  font: var(--font-weight-medium) var(--fs-body)/1 var(--font-sans);
  text-align: center;
  background: var(--color-surface);
}

/* Add to cart button */
.rlm-pdp__summary .single_add_to_cart_button {
  flex: 1;
  min-width: 200px;
  padding: var(--space-3) var(--space-5);
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: var(--radius-button);
  font: var(--font-weight-semibold) var(--fs-body)/1 var(--font-sans);
  cursor: pointer;
  transition: background-color var(--duration-150) var(--ease-standard);
}

.rlm-pdp__summary .single_add_to_cart_button:hover {
  background: var(--color-primary-strong);
}

.rlm-pdp__summary .single_add_to_cart_button:disabled {
  background: var(--gray-300);
  cursor: not-allowed;
}

/* Variations form */
.rlm-pdp__summary .variations {
  width: 100%;
  margin: 0; /* No margin - parent uses gap */
  border-collapse: separate;
  border-spacing: 0 var(--space-2);
}

.rlm-pdp__summary .variations tr {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3);
  align-items: center;
}

.rlm-pdp__summary .variations .label {
  font: var(--font-weight-medium) var(--fs-body)/1 var(--font-sans);
  color: var(--color-text);
}

.rlm-pdp__summary .variations .value {
  width: 100%;
}

.rlm-pdp__summary .variations select {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-input);
  font: var(--font-weight-regular) var(--fs-body)/1 var(--font-sans);
  background: var(--color-surface);
}

/* Reset variation button */
.rlm-pdp__summary .reset_variations {
  font-size: var(--fs-small);
  color: var(--color-primary);
  text-decoration: none;
  margin-left: var(--space-2);
}

.rlm-pdp__summary .reset_variations:hover {
  text-decoration: underline;
}

/* ==========================================================================
   PRODUCT META
   ========================================================================== */

/**
 * Product meta (SKU, categories, tags)
 * - Card-style presentation
 * - Design system colors
 */
.rlm-pdp__summary .product_meta {
  padding: var(--space-3);
  background: var(--color-surface-alt);
  border-radius: var(--radius-lg);
  font-size: var(--fs-small);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
}

.rlm-pdp__summary .product_meta > span {
  display: block;
  margin-bottom: var(--space-2);
}

.rlm-pdp__summary .product_meta > span:last-child {
  margin-bottom: 0;
}

.rlm-pdp__summary .product_meta a {
  color: var(--color-primary);
  text-decoration: none;
}

.rlm-pdp__summary .product_meta a:hover {
  text-decoration: underline;
}

/* ==========================================================================
   FULL-WIDTH CONTENT AREA (Tabs, Related Products)
   ========================================================================== */

/**
 * Content area below the grid
 * - Uses flexbox for consistent ordering
 * - Design system spacing
 */
.rlm-pdp__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  margin-top: 0;
}

/* Ensure correct ordering */
.rlm-pdp__content .woocommerce-tabs {
  order: 1;
}

.rlm-pdp__content .woocommerce-compare-single-product,
.rlm-pdp__content h2.woocommerce-compare-single-product-title {
  order: 2;
}

.rlm-pdp__content .related.products,
.rlm-pdp__content .upsells.products {
  order: 3;
}

/* ==========================================================================
   PRODUCT TABS
   ========================================================================== */

/**
 * WooCommerce tabs (Description, Additional Info, Reviews)
 * - Design system tab component
 * - Accessible with keyboard navigation
 */
.rlm-pdp__content .woocommerce-tabs {
  width: 100%;
  margin-top: 0;
}

.rlm-pdp__content .woocommerce-tabs .tabs {
  display: flex;
  gap: var(--space-1);
  border-bottom: 2px solid var(--color-border);
  margin-bottom: var(--space-5);
  padding: 0;
  list-style: none;
  overflow-x: auto; /* Horizontal scroll on mobile if needed */
  -webkit-overflow-scrolling: touch;
}

.rlm-pdp__content .woocommerce-tabs .tabs li {
  margin: 0;
  flex-shrink: 0; /* Prevent tab text wrapping */
}

.rlm-pdp__content .woocommerce-tabs .tabs li a {
  display: block;
  padding: var(--space-3) var(--space-4);
  color: var(--color-text);
  text-decoration: none;
  font-weight: var(--font-weight-medium);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--duration-150) var(--ease-standard);
  white-space: nowrap;
}

@media (min-width: 768px) {
  .rlm-pdp__content .woocommerce-tabs .tabs li a {
    padding: var(--space-3) var(--space-5);
  }
}

.rlm-pdp__content .woocommerce-tabs .tabs li a:hover {
  color: var(--color-primary);
}

.rlm-pdp__content .woocommerce-tabs .tabs li.active a {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
}

/* Tab panels */
.rlm-pdp__content .woocommerce-tabs .panel {
  padding: var(--space-4) 0;
}

.rlm-pdp__content .woocommerce-tabs .panel h2 {
  font: var(--font-weight-semibold) var(--fs-h3)/var(--lh-tight) var(--font-sans);
  color: var(--color-heading);
  margin-bottom: var(--space-4);
}

/* ==========================================================================
   ADDITIONAL INFORMATION TABLE (Specs)
   ========================================================================== */

/**
 * Product attributes table
 * - Responsive with word wrapping
 * - Design system card styling
 */
.rlm-pdp__content .woocommerce-product-attributes {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

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

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

.rlm-pdp__content .woocommerce-product-attributes th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  background: var(--color-surface-alt);
  color: var(--color-heading);
  font-weight: var(--font-weight-semibold);
  width: 35%;
  vertical-align: top;
}

.rlm-pdp__content .woocommerce-product-attributes td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-text);
  word-wrap: break-word;
  overflow-wrap: break-word;
  max-width: 0; /* Force table to respect container */
}

.rlm-pdp__content .woocommerce-product-attributes td p {
  margin: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

/* Mobile: Stack table rows */
@media (max-width: 640px) {
  .rlm-pdp__content .woocommerce-product-attributes {
    display: block;
  }

  .rlm-pdp__content .woocommerce-product-attributes tr {
    display: block;
    margin-bottom: var(--space-3);
  }

  .rlm-pdp__content .woocommerce-product-attributes th,
  .rlm-pdp__content .woocommerce-product-attributes td {
    display: block;
    width: 100%;
    padding: var(--space-2) var(--space-3);
  }

  .rlm-pdp__content .woocommerce-product-attributes th {
    padding-bottom: var(--space-1);
  }
}

/* ==========================================================================
   REVIEWS SECTION
   ========================================================================== */

/**
 * Product reviews
 * - Design system spacing
 * - Accessible comment threading
 */
.rlm-pdp__content #reviews .commentlist {
  padding: 0;
  list-style: none;
  margin: 0;
}

.rlm-pdp__content #reviews .comment {
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}

.rlm-pdp__content #reviews .comment:last-child {
  border-bottom: none;
}

.rlm-pdp__content #reviews .comment_container {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
}

.rlm-pdp__content #reviews .comment-text {
  color: var(--color-text);
  line-height: var(--lh-relaxed);
}

/* Review form */
.rlm-pdp__content #review_form_wrapper {
  margin-top: var(--space-6);
}

/* ==========================================================================
   RELATED PRODUCTS
   ========================================================================== */

/**
 * Related/Upsell products
 * - Responsive grid
 * - Reuses product card styles
 */
.rlm-pdp__content .related.products,
.rlm-pdp__content .upsells.products {
  margin-top: var(--space-8);
}

.rlm-pdp__content .related.products h2,
.rlm-pdp__content .upsells.products h2 {
  font: var(--font-weight-semibold) var(--fs-h3)/var(--lh-tight) var(--font-sans);
  color: var(--color-heading);
  margin-bottom: var(--space-5);
}

.rlm-pdp__content .related.products ul.products,
.rlm-pdp__content .upsells.products ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-4);
  list-style: none;
  padding: 0;
  margin: 0;
}

@media (min-width: 768px) {
  .rlm-pdp__content .related.products ul.products,
  .rlm-pdp__content .upsells.products ul.products {
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  }
}

/* ==========================================================================
   ACCESSIBILITY & FOCUS STATES
   ========================================================================== */

/**
 * Keyboard navigation and screen readers
 * - Visible focus indicators
 * - Skip to content
 */
.rlm-pdp a:focus-visible,
.rlm-pdp button:focus-visible,
.rlm-pdp input:focus-visible,
.rlm-pdp select:focus-visible {
  outline: 2px solid var(--focus-ring-color, var(--color-primary));
  outline-offset: 2px;
}

/* ==========================================================================
   WOOCOMMERCE & THEME OVERRIDES (PDP-SPECIFIC)
   ========================================================================== */

/**
 * These overrides target WooCommerce/GeneratePress styles that interfere
 * with the PDP template. They are scoped to .rlm-pdp or body.single-product.
 *
 * !important is required to override inline styles from WooCommerce/GeneratePress.
 */

/* PDP Breadcrumb styling */
body.single-product .woocommerce-breadcrumb,
body.single-product .breadcrumb-trail {
  padding-top: var(--space-3) !important;
  padding-bottom: var(--space-3) !important;
  border-bottom: var(--border-width-1) solid var(--color-border) !important;
  margin-bottom: var(--space-5) !important;
}

/* Remove any default borders from inner WooCommerce gallery */
body.single-product .woocommerce-product-gallery {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
}

/* Remove margin from GeneratePress .site-main on PDP */
body.separate-containers.single-product .site-main {
  margin: 0 !important;
}

/* Remove all padding from product article on PDP */
/* Padding is controlled at .inside-article level instead */
body.separate-containers.single-product .site-main > article.product {
  padding: 0 !important;
}

/* Remove backgrounds and border-radius from PDP container hierarchy */
body.single-product .site.grid-container.container.hfeed,
.separate-containers .site-main > article,
.separate-containers .inside-article,
.rlm-pdp {
  background: transparent !important;
  border-radius: 0 !important;
}

/* Fallback container constraints */
.rlm-pdp {
  margin-left: auto;
  margin-right: auto;
  padding: 0;
  width: 100%;
}

/* Add side padding when container is full-width (below max-width) */
/* Only apply to ONE container level to avoid double padding */
body.single-product .inside-article {
  padding-left: var(--space-3) !important;
  padding-right: var(--space-3) !important;
}

/* Remove side padding when container reaches max-width and has auto margins */
@media (min-width: 1300px) {
  body.single-product .inside-article {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* Prevent grid from expanding beyond container */
.rlm-pdp__grid {
  min-width: 0 !important;
  overflow: hidden !important;
}

/* Prevent WooCommerce's .images class from breaking our grid */
.rlm-pdp__gallery.images {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin: 0 !important;
  overflow: hidden !important;
  min-width: 0 !important;
}

/* Constrain all images within gallery to container */
.rlm-pdp__gallery img,
.rlm-pdp__gallery .woocommerce-product-gallery__image img {
  max-width: 100% !important;
  height: auto !important;
  max-height: 500px !important;
  object-fit: contain !important;
}

/* Prevent WooCommerce's .entry-summary from breaking our grid */
.rlm-pdp__summary.entry-summary {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}

/* Fix content area ordering - prevent compare section from appearing before tabs */
.rlm-pdp__content {
  display: flex !important;
  flex-direction: column !important;
}

/* Ensure tabs appear first */
.rlm-pdp .woocommerce-tabs {
  order: 1 !important;
  margin-top: var(--space-6);
}

/* Move compare section after tabs */
.rlm-pdp .woocommerce-compare-single-product,
.rlm-pdp h2.woocommerce-compare-single-product-title {
  order: 2 !important;
}

/* Related products appear last */
.rlm-pdp .related.products,
.rlm-pdp .upsells.products {
  order: 3 !important;
}

/* Standard tab design system - button-style tabs */
.rlm-pdp .woocommerce-tabs .tabs {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: var(--space-1) !important;
  background: var(--color-surface-alt) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--space-1) !important;
  box-shadow: inset 0px 0px 2px rgba(0, 0, 0, 0.2) !important;
  margin-bottom: var(--space-5) !important;
  margin-top: 0 !important;
  list-style: none !important;
  border: none !important;
  border-bottom: none !important;
}

.rlm-pdp .woocommerce-tabs .tabs::before,
.rlm-pdp .woocommerce-tabs .tabs::after {
  display: none !important;
}

.rlm-pdp .woocommerce-tabs .tabs li {
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
}

.rlm-pdp .woocommerce-tabs .tabs li::before,
.rlm-pdp .woocommerce-tabs .tabs li::after {
  display: none !important;
}

.rlm-pdp .woocommerce-tabs .tabs li a {
  display: block !important;
  padding: var(--space-2) var(--space-4) !important;
  border-radius: var(--radius-md) !important;
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  text-decoration: none !important;
  border: var(--border-width-1) solid var(--color-border) !important;
  cursor: pointer !important;
  font: var(--font-weight-medium) var(--fs-body)/var(--lh-normal) var(--font-sans) !important;
  transition: all var(--duration-200) var(--ease-standard) !important;
  position: relative !important;
  min-width: 80px !important;
  text-align: center !important;
  margin: 0 !important;
  margin-bottom: 0 !important;
  box-shadow: none !important;
}

.rlm-pdp .woocommerce-tabs .tabs li a::before,
.rlm-pdp .woocommerce-tabs .tabs li a::after {
  display: none !important;
}

.rlm-pdp .woocommerce-tabs .tabs li a:hover {
  color: var(--color-heading) !important;
  background: rgba(255, 255, 255, 0.8) !important;
  background: color-mix(in oklab, var(--color-surface), transparent 20%) !important;
  border-color: var(--color-primary) !important;
}

.rlm-pdp .woocommerce-tabs .tabs li.active a {
  background: var(--color-primary) !important;
  box-shadow: var(--shadow-sm) !important;
  color: white !important;
  font-weight: var(--font-weight-semibold) !important;
  transform: translateY(-1px) !important;
  border-color: var(--color-primary) !important;
}

.rlm-pdp .woocommerce-tabs .tabs li a:focus-visible {
  outline: 2px solid var(--color-primary) !important;
  outline-offset: 2px !important;
}

.rlm-pdp .woocommerce-tabs .panel {
  padding: var(--space-4) 0;
}

/* ==========================================================================
   PRODUCT SPECIFICATIONS TABLE
   ========================================================================== */

/**
 * WooCommerce Grouped Attributes Table
 * Matches design system .table-clean styling
 * Override WooCommerce default border styles
 */
.rlm-pdp .shop_attributes,
.rlm-pdp .woocommerce-group-attributes-layout-1,
.rlm-pdp .shop_attributes.woocommerce-group-attributes-layout-1,
.rlm-pdp .shop_attributes.woocommerce-group-attributes-layout-2,
.rlm-pdp .shop_attributes.woocommerce-group-attributes-layout-3 {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  font-size: var(--fs-body);
  background: var(--color-surface);
  border: var(--border-width-1) solid var(--color-border) !important;
  border-top: var(--border-width-1) solid var(--color-border) !important;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin: var(--space-4) 0 !important;
  margin-bottom: var(--space-4) !important;
}

/* Group header rows */
.rlm-pdp .shop_attributes .attribute_group_row th,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_group_row th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  color: var(--color-heading);
  font-weight: var(--font-weight-semibold);
  font-size: var(--fs-body);
  border-bottom: var(--border-width-1) solid var(--color-border);
  background: var(--color-surface-alt);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Nested attribute table within group rows */
.rlm-pdp .shop_attributes .attribute_name_values,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name_values {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}

/* Attribute name cells (left column) */
.rlm-pdp .shop_attributes .attribute_name,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name {
  padding: var(--space-3) var(--space-4) !important;
  text-align: left !important;
  color: var(--color-text-strong);
  font-weight: var(--font-weight-medium);
  font-size: var(--fs-body);
  border-bottom: var(--border-width-1) solid var(--color-border) !important;
  border-right: none !important;
  background: var(--color-surface-alt) !important;
  width: 35% !important; /* Fixed width for label column */
  vertical-align: top;
}

/* Attribute value cells (right column) */
.rlm-pdp .shop_attributes .attribute_value,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_value {
  padding: var(--space-3) var(--space-4) !important;
  text-align: left !important;
  color: var(--color-text);
  border-bottom: var(--border-width-1) solid var(--color-border) !important;
  border-left: none !important;
  border-right: none !important;
  background: var(--color-surface) !important;
  vertical-align: top;
}

/* Remove paragraphs margins inside table cells */
.rlm-pdp .shop_attributes .attribute_value p,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_value p {
  margin: 0;
}

/* Striped rows for better readability */
.rlm-pdp .shop_attributes .attribute_name_values tr.alt .attribute_name,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name_values tr.alt .attribute_name {
  background: color-mix(in oklab, var(--color-surface-alt), transparent 30%);
}

.rlm-pdp .shop_attributes .attribute_name_values tr.alt .attribute_value,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name_values tr.alt .attribute_value {
  background: color-mix(in oklab, var(--color-surface-alt), transparent 70%);
}

/* Hover effect on rows */
.rlm-pdp .shop_attributes .attribute_name_values tr:hover .attribute_name,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name_values tr:hover .attribute_name,
.rlm-pdp .shop_attributes .attribute_name_values tr:hover .attribute_value,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name_values tr:hover .attribute_value {
  background: color-mix(in oklab, var(--color-surface-alt), transparent 50%);
}

/* Remove border from last row */
.rlm-pdp .shop_attributes .attribute_name_values tr:last-child .attribute_name,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name_values tr:last-child .attribute_name,
.rlm-pdp .shop_attributes .attribute_name_values tr:last-child .attribute_value,
.rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name_values tr:last-child .attribute_value {
  border-bottom: none !important;
}

/* Mobile responsive - stack on small screens */
@media (max-width: 640px) {
  .rlm-pdp .shop_attributes .attribute_name,
  .rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_name {
    width: 40%;
    font-size: var(--fs-small);
  }

  .rlm-pdp .shop_attributes .attribute_value,
  .rlm-pdp .woocommerce-group-attributes-layout-1 .attribute_value {
    font-size: var(--fs-small);
  }
}

/* ===== QUANTITY INPUT - DESIGN SYSTEM ALIGNMENT ===== */
.rlm-pdp .quantity {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0 !important;
  border: var(--border-width-1) solid var(--color-border) !important;
  border-radius: var(--radius-input) !important;
  background: var(--color-surface) !important;
  overflow: hidden !important;
}

.rlm-pdp .quantity input[type="number"],
.rlm-pdp .quantity input.qty {
  width: 60px !important;
  height: 42px !important;
  min-height: unset !important;
  padding: var(--input-padding-y) var(--space-2) !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  font: var(--font-weight-medium) var(--fs-body)/var(--lh-normal) var(--font-sans) !important;
  color: var(--color-text) !important;
  text-align: center !important;
  -moz-appearance: textfield !important;
  appearance: textfield !important;
}

.rlm-pdp .quantity input[type="number"]::-webkit-outer-spin-button,
.rlm-pdp .quantity input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

.rlm-pdp .quantity input[type="number"]:focus,
.rlm-pdp .quantity input.qty:focus {
  outline: none !important;
  box-shadow: none !important;
}

.rlm-pdp .quantity .minus,
.rlm-pdp .quantity .plus {
  width: 42px !important;
  height: 42px !important;
  min-width: unset !important;
  min-height: unset !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  background: var(--color-surface-alt) !important;
  color: var(--color-text) !important;
  font-size: 18px !important;
  font-weight: var(--font-weight-semibold) !important;
  line-height: 1 !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background var(--duration-100) var(--ease-standard), color var(--duration-100) var(--ease-standard) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.rlm-pdp .quantity .minus:hover,
.rlm-pdp .quantity .plus:hover {
  background: var(--color-primary) !important;
  color: white !important;
}

.rlm-pdp .quantity .minus:active,
.rlm-pdp .quantity .plus:active {
  transform: scale(0.95) !important;
}

.rlm-pdp .quantity .minus:focus-visible,
.rlm-pdp .quantity .plus:focus-visible {
  outline: 2px solid var(--color-primary) !important;
  outline-offset: -2px !important;
  z-index: 1 !important;
}

.rlm-pdp .quantity .minus {
  border-right: var(--border-width-1) solid var(--color-border) !important;
}

.rlm-pdp .quantity .plus {
  border-left: var(--border-width-1) solid var(--color-border) !important;
}

/* Additional information table (specs) - WITH TABLE WRAPPING FIX */
.rlm-pdp .woocommerce-product-attributes {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

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

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

.rlm-pdp .woocommerce-product-attributes th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  background: var(--color-surface-alt);
  color: var(--color-heading);
  font-weight: var(--font-weight-semibold);
  width: 30%;
}

.rlm-pdp .woocommerce-product-attributes td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-text);
  word-wrap: break-word;
  overflow-wrap: break-word;
  word-break: break-word;
  max-width: 0;
}

.rlm-pdp .woocommerce-product-attributes td p {
  margin: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

@media (max-width: 640px) {
  .rlm-pdp .woocommerce-product-attributes {
    display: block;
    overflow-x: auto;
  }

  .rlm-pdp .woocommerce-product-attributes th,
  .rlm-pdp .woocommerce-product-attributes td {
    min-width: 100px;
  }
}

/* Reviews */
.rlm-pdp #reviews .commentlist {
  padding: 0;
  list-style: none;
}

.rlm-pdp #reviews .comment {
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}

.rlm-pdp #reviews .comment:last-child {
  border-bottom: none;
}

/* Related products */
.rlm-pdp .related.products {
  margin-top: var(--space-8);
}

.rlm-pdp .related.products h2 {
  font: var(--font-weight-semibold) var(--fs-h3)/var(--lh-tight) var(--font-sans);
  color: var(--color-heading);
  margin-bottom: var(--space-5);
}

.rlm-pdp .related.products ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-4);
  list-style: none;
  padding: 0;
  margin: 0;
}

/* ==========================================================================
   PRINT STYLES
   ========================================================================== */

@media print {
  .rlm-pdp__grid {
    grid-template-columns: 1fr !important;
  }

  .rlm-pdp__gallery {
    position: static !important;
  }

  .rlm-pdp__content .woocommerce-tabs .tabs {
    display: none;
  }

  .rlm-pdp__content .woocommerce-tabs .panel {
    display: block !important;
  }
}
