/**
 * Tree-Ripe Custom Product Page Styles
 * Based on Layout 17 prototype
 *
 * All rules scoped under .tr-product-page to avoid conflicts
 */

/* ============================================
   CSS Variables
   ============================================ */
.tr-product-page {
  --forest: #0F5E41;
  --medium: #408469;
  --black: #333333;
  --secondary: #333333;
  --border: #E6E0D6;
  --white: #FFF;
  --star: #0F5E41;
  --fd: Georgia, 'Times New Roman', serif;
  --fu: 'Avenir Next', 'Avenir', system-ui, sans-serif;
  --fb: 'Avenir', 'Avenir Next', system-ui, sans-serif;

  font-family: var(--fb);
  font-size: 16px;
  line-height: 1.7;
  color: var(--black);
  -webkit-font-smoothing: antialiased;

  box-shadow: none !important;
  border-radius: 0 !important;
  border: none !important;
}

.entry.tr-product-page,
.tr-product-page.entry {
  box-shadow: none !important;
  border-radius: 0 !important;
  border: none !important;
}

/* Kill Kadence blockquote/quote styles */
.tr-product-page blockquote,
body .tr-product-page blockquote {
  padding-left: 0 !important;
  border-left: none !important;
  margin: 0 !important;
  quotes: none !important;
}
.tr-product-page q,
body .tr-product-page q {
  quotes: none !important;
}

/* Kill breadcrumbs no matter where Kadence puts them */
.tr-product-page .woocommerce-breadcrumb,
.tr-product-page .kadence-breadcrumbs,
.tr-product-page .breadcrumb,
.tr-product-page [class*="breadcrumb"] {
  display: none !important;
}


/* ============================================
   HERO
   ============================================ */
.tr-product-page .tr-pp-hero-band {
  background: var(--white);
  padding: clamp(24px, 4vw, 48px) clamp(20px, 4vw, 48px) 0;
  max-width: 1300px;
  margin: 0 auto;
}

.tr-product-page .tr-pp-hero {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}


/* --- Gallery --- */
.tr-product-page .tr-pp-gallery {
  position: relative;
  opacity: 0;
  animation: trPpFadeUp 0.7s ease 0.1s forwards;
}

.tr-product-page .tr-pp-gallery-main {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(15, 94, 65, 0.1);
}

.tr-product-page .tr-pp-gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.4s ease;
}

.tr-product-page .tr-pp-gallery-main img.hidden {
  opacity: 0;
  position: absolute;
  inset: 0;
}

.tr-product-page .tr-pp-gallery-main img.active {
  opacity: 1;
}

.tr-product-page .tr-pp-gallery-thumbs {
  display: flex;
  gap: 10px;
  margin-top: 14px;
}

.tr-product-page .tr-pp-thumb {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color 0.2s, transform 0.2s;
  background: #eeeeee;
  padding: 0;
}

.tr-product-page .tr-pp-thumb:hover {
  transform: scale(1.06);
}

.tr-product-page .tr-pp-thumb.active {
  border-color: var(--forest);
}

.tr-product-page .tr-pp-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


/* --- Product Info --- */
.tr-product-page .tr-pp-product-info {
  opacity: 0;
  animation: trPpFadeUp 0.7s ease 0.3s forwards;
  padding-top: 12px;
}

.tr-product-page .tr-pp-badges {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.tr-product-page .tr-pp-badge,
body .tr-product-page .tr-pp-badge,
body .tr-product-page span.tr-pp-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 5px 14px !important;
  border-radius: 100px !important;
  font-family: var(--fu) !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  line-height: 1.3 !important;
}

.tr-product-page .tr-pp-badge svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
}

.tr-product-page .tr-pp-badge-available,
body .tr-product-page .tr-pp-badge-available,
body .tr-product-page span.tr-pp-badge-available {
  background: #0F5E41 !important;
  background-color: #0F5E41 !important;
  color: #FFF !important;
}

.tr-product-page .tr-pp-badge-status,
body .tr-product-page .tr-pp-badge-status,
body .tr-product-page span.tr-pp-badge-status {
  border: 1.5px solid #0F5E41 !important;
  color: #0F5E41 !important;
  background: transparent !important;
}

.tr-product-page .tr-pp-title {
  font-family: var(--fd);
  font-size: clamp(34px, 5vw, 52px);
  font-weight: 700;
  color: var(--black);
  line-height: 1.1;
  margin-bottom: 14px;
}

.tr-product-page .tr-pp-rating {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 20px;
}

.tr-product-page .tr-pp-stars {
  display: flex;
  gap: 2px;
}

.tr-product-page .tr-pp-stars svg {
  width: 17px;
  height: 17px;
  color: var(--star);
}

.tr-product-page .tr-pp-stars .empty {
  color: var(--border);
}

.tr-product-page .tr-pp-rating-text {
  font-family: var(--fu);
  font-size: 15px;
  color: var(--secondary);
  text-decoration: none;
}

.tr-product-page .tr-pp-rating-text:hover {
  color: var(--forest);
  text-decoration: underline;
}

.tr-product-page .tr-pp-pitch {
  font-family: var(--fd);
  font-size: clamp(16px, 1.6vw, 18px);
  font-style: italic;
  color: var(--secondary);
  line-height: 1.65;
  margin-bottom: 24px;
}

.tr-product-page .tr-pp-pitch p {
  margin: 0;
}


/* Fun Bits */
.tr-product-page .tr-pp-fun-bits {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 20px;
  margin-bottom: 28px;
}

.tr-product-page .tr-pp-fun-bit {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fu);
  font-size: 15px;
  color: var(--black);
}

.tr-product-page .tr-pp-fun-bit svg {
  width: 18px;
  height: 18px;
  color: var(--medium);
  flex-shrink: 0;
}

.tr-product-page .tr-pp-fun-bit-full {
  flex-basis: 100%;
}

.tr-product-page .tr-pp-fun-bit-divider {
  width: 1px;
  height: 20px;
  background: var(--border);
  flex-shrink: 0;
}


/* Notices */
.tr-product-page .tr-pp-notice {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 12px;
  margin-bottom: 12px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--black);
}

.tr-product-page .tr-pp-notice svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}

.tr-product-page .tr-pp-notice-warn,
.tr-product-page .tr-pp-product-info .tr-pp-notice-warn,
body .tr-product-page .tr-pp-notice.tr-pp-notice-warn {
  background: #E8F4EB;
  padding: 12px 16px;
  margin-bottom: 32px !important;
}

/* Override any inner styling from the shortcode output */
.tr-product-page .tr-pp-notice-warn * {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  font-family: var(--fb) !important;
  font-size: 15px !important;
  color: var(--black) !important;
}

.tr-product-page .tr-pp-notice-warn img,
.tr-product-page .tr-pp-notice-warn svg {
  width: 18px !important;
  height: 18px !important;
}

/* Status note — italic text below purchase area */
.tr-product-page .tr-pp-status-note {
  font-family: var(--fb);
  font-size: 15px;
  font-style: italic;
  color: #666666;
  margin: -32px 0 48px;
  padding: 0;
  line-height: 1.5;
}


/* Price */
.tr-product-page .tr-pp-price-line {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 20px;
  margin-top: 4px;
}

.tr-product-page .tr-pp-price {
  font-family: var(--fd);
  font-size: clamp(28px, 3.5vw, 38px);
  font-weight: 700;
  color: var(--forest);
  line-height: 1;
}

/* WooCommerce price elements inside our wrapper */
.tr-product-page .tr-pp-price .woocommerce-Price-amount {
  font-family: var(--fd);
  font-size: inherit;
  font-weight: 700;
  color: var(--forest);
}

.tr-product-page .tr-pp-price del {
  opacity: 0.5;
  font-size: 0.7em;
}

.tr-product-page .tr-pp-price ins {
  text-decoration: none;
}


/* ============================================
   ADD TO CART — WooCommerce Native (Restyled)
   ============================================ */
.tr-product-page .tr-pp-purchase {
  margin-top: 8px;
  margin-bottom: 48px;
}

.tr-product-page .tr-pp-out-of-stock {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--black);
  padding: 1rem 0 0.25rem;
  margin: 0;
}

.tr-product-page .tr-pp-out-of-stock-hint {
  font-size: 0.9rem;
  color: #666666;
  margin: 0;
  padding-bottom: 1rem;
}

/* Top border only for variable products (has variation selector) */
.tr-product-page .tr-pp-purchase:has(.variations) {
  padding-top: 20px;
  border-top: 1px solid var(--border);
}

/* Simple product form */
.tr-product-page .tr-pp-purchase form.cart {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
}

/* Hide ALL Kadence/WooCommerce quantity buttons outside our pill */
.tr-product-page .tr-pp-purchase button.minus:not(.tr-qty-btn),
.tr-product-page .tr-pp-purchase button.plus:not(.tr-qty-btn),
.tr-product-page .tr-pp-purchase form.cart > button.minus,
.tr-product-page .tr-pp-purchase form.cart > button.plus,
.tr-product-page .tr-pp-purchase .quantity:not(.tr-qty-pill) button,
.tr-product-page .tr-pp-purchase .kwt-add-to-cart-wrap button.minus,
.tr-product-page .tr-pp-purchase .kwt-add-to-cart-wrap button.plus,
body .tr-product-page button.minus:not(.tr-qty-btn),
body .tr-product-page button.plus:not(.tr-qty-btn) {
  display: none !important;
}

/* ---- Custom quantity pill (tr-qty-pill) ---- */
.tr-product-page .tr-qty-pill,
body .tr-product-page .tr-qty-pill,
body .tr-product-page .tr-pp-purchase .tr-qty-pill,
body .tr-product-page div.quantity.tr-qty-pill {
  display: inline-flex !important;
  align-items: stretch !important;
  border: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
  width: auto !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  height: auto !important;
  min-height: 0 !important;
}

/* Shared base for all three pill children */
.tr-product-page .tr-qty-btn,
body .tr-product-page button.tr-qty-btn {
  flex: 0 0 48px !important;
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  max-width: 48px !important;
  min-height: 48px !important;
  background: #fff !important;
  background-color: #fff !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--black) !important;
  font-size: 20px !important;
  line-height: 1 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  outline: 2px solid transparent !important;
  outline-offset: 3px !important;
  transition: background 0.15s !important;
  border: 1.5px solid var(--border) !important;
  box-sizing: border-box !important;
}

/* Minus: rounded left, flat right */
.tr-product-page .tr-qty-minus,
body .tr-product-page button.tr-qty-minus {
  border-radius: 100px 0 0 100px !important;
  border-right: none !important;
}

/* Plus: flat left, rounded right */
.tr-product-page .tr-qty-plus,
body .tr-product-page button.tr-qty-plus {
  border-radius: 0 100px 100px 0 !important;
  border-left: none !important;
}

.tr-product-page .tr-qty-btn svg {
  display: block !important;
  color: var(--black) !important;
  flex-shrink: 0 !important;
}

.tr-product-page .tr-qty-btn:hover,
body .tr-product-page button.tr-qty-btn:hover {
  background: #E6E0D6 !important;
  background-color: #E6E0D6 !important;
}

.tr-product-page .tr-qty-btn:disabled,
body .tr-product-page button.tr-qty-btn:disabled {
  cursor: not-allowed !important;
  opacity: 0.52 !important;
}

.tr-product-page .tr-qty-btn:focus-visible,
body .tr-product-page button.tr-qty-btn:focus-visible {
  outline-color: #0F5E41 !important;
  box-shadow: 0 0 0 4px rgba(15, 94, 65, 0.16) !important;
}

/* Input: flat sides, bordered top/bottom + left/right dividers */
.tr-product-page .tr-qty-pill input.qty,
body .tr-product-page .tr-qty-pill input.qty,
body .tr-product-page .tr-qty-pill input[type="number"].qty,
body .tr-product-page .tr-pp-purchase .tr-qty-pill input.qty,
body .woocommerce div.product .tr-qty-pill input.qty {
  flex: 0 0 48px !important;
  width: 48px !important;
  min-width: 48px !important;
  max-width: 48px !important;
  height: 48px !important;
  border: 1.5px solid var(--border) !important;
  border-left: 1.5px solid var(--border) !important;
  border-right: 1.5px solid var(--border) !important;
  border-radius: 0 !important;
  background: #fff !important;
  background-color: #fff !important;
  text-align: center !important;
  font-family: var(--fu) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--black) !important;
  line-height: 48px !important;
  margin: 0 !important;
  padding: 0 !important;
  -moz-appearance: textfield !important;
  appearance: textfield !important;
  outline: 2px solid transparent !important;
  outline-offset: 3px !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}

.tr-product-page .tr-qty-pill input.qty::-webkit-inner-spin-button,
.tr-product-page .tr-qty-pill input.qty::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

.tr-product-page .tr-qty-pill input.qty:focus-visible,
body .tr-product-page .tr-qty-pill input.qty:focus-visible {
  border-color: #0F5E41 !important;
  outline-color: #0F5E41 !important;
  box-shadow: 0 0 0 4px rgba(15, 94, 65, 0.16) !important;
}

/* Add to cart button — maximum specificity to beat Kadence */
.tr-product-page .tr-pp-purchase .single_add_to_cart_button,
.tr-product-page .tr-pp-purchase button.single_add_to_cart_button,
.tr-product-page .tr-pp-purchase button[type="submit"].single_add_to_cart_button,
.woocommerce div.product .tr-pp-purchase .single_add_to_cart_button,
.woocommerce div.product .tr-pp-purchase button.single_add_to_cart_button,
body .tr-product-page .single_add_to_cart_button,
body .tr-product-page button.single_add_to_cart_button,
body .tr-product-page .tr-pp-purchase button.single_add_to_cart_button,
body.woocommerce .tr-product-page .single_add_to_cart_button,
body.single-product .tr-product-page .single_add_to_cart_button,
body .woocommerce .tr-product-page button.single_add_to_cart_button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  padding: 14px 36px !important;
  border-radius: 100px !important;
  border: none !important;
  background: #0F5E41 !important;
  background-color: #0F5E41 !important;
  background-image: none !important;
  color: #FFF !important;
  font-family: 'Avenir Next', 'Avenir', system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background-color 0.2s, transform 0.2s, box-shadow 0.25s !important;
  min-height: 50px !important;
  line-height: 1.3 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  text-shadow: none !important;
  box-shadow: none !important;
  opacity: 1 !important;
}

/* Space between pill and button on desktop */
@media screen and (min-width: 576px) {
  .kadence-cart-button-medium-large.woocommerce div.product .button.single_add_to_cart_button {
    width: auto !important;
    margin-left: 18px !important;
  }
}

/* Kill any ::after icons */
.tr-product-page .tr-pp-purchase .single_add_to_cart_button::after,
body .tr-product-page .single_add_to_cart_button::after {
  content: none !important;
  display: none !important;
}

.tr-product-page .tr-pp-purchase .single_add_to_cart_button:hover,
body .tr-product-page .single_add_to_cart_button:hover,
body.single-product .tr-product-page .single_add_to_cart_button:hover {
  background: #0F5E41 !important;
  background-color: #0F5E41 !important;
  background-image: none !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(15, 94, 65, 0.25) !important;
}

.tr-product-page .tr-pp-purchase .single_add_to_cart_button.disabled,
.tr-product-page .tr-pp-purchase .single_add_to_cart_button.wc-variation-selection-needed,
body .tr-product-page .single_add_to_cart_button.disabled,
body .tr-product-page .single_add_to_cart_button.wc-variation-selection-needed {
  background: #0F5E41 !important;
  background-color: #0F5E41 !important;
  color: #FFF !important;
  opacity: 0.5 !important;
  cursor: not-allowed !important;
}

.tr-product-page .tr-pp-purchase .single_add_to_cart_button.disabled:hover,
.tr-product-page .tr-pp-purchase .single_add_to_cart_button.wc-variation-selection-needed:hover {
  transform: none !important;
  box-shadow: none !important;
  background: #0F5E41 !important;
}

/* View Cart link after add */
.tr-product-page .tr-pp-purchase a.added_to_cart {
  display: inline-flex !important;
  align-items: center !important;
  padding: 12px 24px !important;
  border-radius: 100px !important;
  background: var(--medium) !important;
  color: var(--white) !important;
  font-family: var(--fu) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: background 0.2s !important;
  min-height: 44px !important;
}

.tr-product-page .tr-pp-purchase a.added_to_cart:hover {
  background: var(--forest) !important;
}

/* Variation table — clean stacked layout */
.tr-product-page .tr-pp-purchase .variations,
body .tr-product-page .tr-pp-purchase .variations,
body.single-product .tr-product-page .variations,
body .woocommerce .tr-product-page .variations {
  width: 100% !important;
  margin-bottom: 20px !important;
  border: none !important;
  border-collapse: collapse !important;
  border-spacing: 0 !important;
}

.tr-product-page .tr-pp-purchase .variations tr,
body .tr-product-page .variations tr {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin-bottom: 20px !important;
  padding: 0 !important;
  border: none !important;
}

.tr-product-page .tr-pp-purchase .variations td,
.tr-product-page .tr-pp-purchase .variations th,
body .tr-product-page .variations td,
body .tr-product-page .variations th {
  padding: 0 !important;
  border: none !important;
  display: block !important;
  width: 100% !important;
  text-align: left !important;
}

.tr-product-page .tr-pp-purchase .variations td.label,
.tr-product-page .tr-pp-purchase .variations th.label,
body .tr-product-page .variations td.label,
body .tr-product-page .variations th.label {
  padding: 0 !important;
  margin: 0 !important;
}

.tr-product-page .tr-pp-purchase .variations td.label label,
.tr-product-page .tr-pp-purchase .variations th.label label,
body .tr-product-page .variations td.label label,
body .tr-product-page .variations th.label label,
body.single-product .tr-product-page .variations label,
body .woocommerce .tr-product-page .variations label {
  font-family: 'Avenir Next', 'Avenir', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #333 !important;
  font-style: normal !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.3 !important;
}

.tr-product-page .tr-pp-purchase .variations td.value,
body .tr-product-page .variations td.value {
  padding: 0 !important;
}

.tr-product-page .tr-pp-purchase .variations select,
body .tr-product-page .tr-pp-purchase .variations select,
body .tr-product-page .variations select,
body.single-product .tr-product-page .variations select,
body .woocommerce .tr-product-page .variations select {
  width: 100% !important;
  max-width: 100% !important;
  padding: 14px 18px !important;
  font-family: 'Avenir', 'Avenir Next', system-ui, sans-serif !important;
  font-size: 16px !important;
  color: #333 !important;
  background: #fff !important;
  background-color: #fff !important;
  border: 1.5px solid #E6E0D6 !important;
  border-radius: 12px !important;
  cursor: pointer !important;
  transition: border-color 0.2s !important;
  appearance: auto !important;
  -webkit-appearance: auto !important;
  min-height: 50px !important;
  height: auto !important;
  box-shadow: none !important;
  outline: 2px solid transparent !important;
  outline-offset: 3px !important;
  font-style: normal !important;
}

.tr-product-page .tr-pp-purchase .variations select:focus,
body .tr-product-page .variations select:focus {
  outline-color: #0F5E41 !important;
  border-color: #0F5E41 !important;
  box-shadow: 0 0 0 3px rgba(15, 94, 65, 0.1) !important;
}

/* Reset link */
.tr-product-page .tr-pp-purchase .variations .reset_variations,
body .tr-product-page .variations .reset_variations {
  font-family: 'Avenir Next', 'Avenir', system-ui, sans-serif !important;
  font-size: 14px !important;
  color: var(--secondary) !important;
  margin-top: 8px !important;
  display: inline-block !important;
}

/* Variation add-to-cart row — quantity + button */
.tr-product-page .tr-pp-purchase .woocommerce-variation-add-to-cart,
body .tr-product-page .woocommerce-variation-add-to-cart {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin-top: 20px !important;
  padding-top: 20px !important;
  border-top: 1px solid #E6E0D6 !important;
}

/* Variation price display */
.tr-product-page .tr-pp-purchase .woocommerce-variation-price,
body .tr-product-page .woocommerce-variation-price {
  margin-bottom: 8px !important;
  margin-top: 16px !important;
}

.tr-product-page .tr-pp-purchase .woocommerce-variation-price .price,
body .tr-product-page .woocommerce-variation-price .price {
  font-family: Georgia, 'Times New Roman', serif !important;
  font-size: clamp(24px, 3vw, 32px) !important;
  font-weight: 700 !important;
  color: #0F5E41 !important;
}

/* Variation description */
.tr-product-page .tr-pp-purchase .woocommerce-variation-description p,
body .tr-product-page .woocommerce-variation-description p {
  font-size: 15px !important;
  color: var(--black) !important;
  margin-bottom: 12px !important;
}

/* Single variation wrap */
.tr-product-page .tr-pp-purchase .single_variation_wrap,
body .tr-product-page .single_variation_wrap {
  width: 100% !important;
}

/* WooCommerce notices inside purchase */
.tr-product-page .tr-pp-purchase .woocommerce-message,
.tr-product-page .tr-pp-purchase .woocommerce-error,
.tr-product-page .tr-pp-purchase .woocommerce-info {
  width: 100%;
  margin-bottom: 12px;
}

/* Kadence add-to-cart wrap */
.tr-product-page .tr-pp-purchase .kwt-add-to-cart-wrap .cart,
.tr-product-page .tr-pp-purchase .kwt-add-to-cart-wrap {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  flex-wrap: wrap;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* Hide any Kadence-injected quantity elements that aren't ours */
.tr-product-page .tr-qty-pill label {
  display: none !important;
}


/* ============================================
   GREEN BAND
   ============================================ */
.tr-product-page .tr-pp-green-band {
  background: var(--forest);
  margin-top: clamp(48px, 7vw, 80px);
  padding: clamp(48px, 7vw, 80px) clamp(24px, 5vw, 64px);
  text-align: center;
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}

.tr-product-page .tr-pp-green-band-inner {
  width: 85vw;
  margin: 0 auto;
}

.tr-product-page .tr-pp-green-band blockquote,
body .tr-product-page .tr-pp-green-band blockquote {
  font-family: var(--fd) !important;
  font-size: clamp(30px, 5vw, 48px) !important;
  font-style: italic !important;
  font-weight: 700 !important;
  color: var(--white) !important;
  line-height: 1.3 !important;
  margin: 0 0 20px 0 !important;
  padding: 0 !important;
  border: none !important;
  border-left: none !important;
  quotes: none !important;
}

.tr-product-page .tr-pp-green-band cite {
  font-family: var(--fu);
  font-size: clamp(17px, 2.2vw, 20px);
  font-weight: 400;
  color: #FFFFFF;
  letter-spacing: 0.01em;
  font-style: normal;
  line-height: 1.6;
}


/* ============================================
   A CLOSER LOOK
   ============================================ */
.tr-product-page .tr-pp-closer-look {
  max-width: 1300px;
  margin: 0 auto;
  padding: clamp(56px, 8vw, 96px) clamp(20px, 4vw, 48px);
}

.tr-product-page .tr-pp-section-heading {
  font-family: var(--fd);
  font-size: clamp(30px, 4.5vw, 44px);
  font-weight: 700;
  color: var(--black);
  margin-bottom: 20px;
  line-height: 1.2;
}

.tr-product-page .tr-pp-closer-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}

.tr-product-page .tr-pp-closer-text p {
  font-size: 18px;
  line-height: 1.85;
  color: var(--secondary);
  margin-bottom: 20px;
}

.tr-product-page .tr-pp-closer-text p:last-child {
  margin-bottom: 0;
}

.tr-product-page .tr-pp-closer-image {
  border-radius: 20px;
  overflow: hidden;
  background: #eeeeee;
}

.tr-product-page .tr-pp-closer-image img {
  width: 100%;
  height: auto;
  display: block;
}


/* ============================================
   LEARN MORE CALLOUT (inside A Closer Look)
   ============================================ */
.tr-product-page .tr-pp-callout {
  margin-top: 32px;
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 24px 28px;
  border: 2px solid var(--forest);
  border-radius: 14px;
  text-decoration: none;
  transition: background 0.2s, transform 0.2s;
}

.tr-product-page .tr-pp-callout:hover {
  background: var(--forest);
  transform: translateY(-2px);
}

.tr-product-page .tr-pp-callout:hover .tr-pp-callout-title,
.tr-product-page .tr-pp-callout:hover .tr-pp-callout-text,
.tr-product-page .tr-pp-callout:hover .tr-pp-callout-arrow {
  color: var(--white);
}

.tr-product-page .tr-pp-callout-icon {
  width: 48px;
  height: 48px;
  min-width: 48px;
  background: var(--forest);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.tr-product-page .tr-pp-callout:hover .tr-pp-callout-icon {
  background: rgba(255, 255, 255, 0.2);
}

.tr-product-page .tr-pp-callout-icon svg {
  width: 24px;
  height: 24px;
  color: var(--white);
}

.tr-product-page .tr-pp-callout-body {
  flex: 1;
}

.tr-product-page .tr-pp-callout-title {
  font-family: var(--fu);
  font-size: 15px;
  font-weight: 700;
  color: var(--forest);
  line-height: 1.3;
  margin-bottom: 3px;
  transition: color 0.2s;
}

.tr-product-page .tr-pp-callout-text {
  font-family: var(--fb);
  font-size: 14px;
  color: #666666;
  line-height: 1.5;
  transition: color 0.2s;
}

.tr-product-page .tr-pp-callout-arrow {
  width: 20px;
  height: 20px;
  color: var(--forest);
  flex-shrink: 0;
  transition: color 0.2s;
}

@media (max-width: 500px) {
  .tr-product-page .tr-pp-callout {
    flex-direction: column;
    text-align: center;
    padding: 20px;
  }

  .tr-product-page .tr-pp-callout-arrow {
    display: none;
  }
}


/* ============================================
   DETAILS + VIDEO — 2-Column
   ============================================ */
.tr-product-page .tr-pp-details-video {
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 48px) clamp(56px, 8vw, 80px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 72px);
  align-items: start;
}

.tr-product-page .tr-pp-accordion-column h2 {
  font-family: var(--fd);
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 700;
  color: var(--black);
  margin-bottom: 20px;
  line-height: 1.2;
}

.tr-product-page .tr-pp-accordion {
  border-top: 2px solid var(--forest);
}

.tr-product-page .tr-pp-accordion-item {
  border-bottom: 1px solid var(--border);
}

.tr-product-page .tr-pp-accordion-trigger,
body .tr-product-page button.tr-pp-accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0 !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  cursor: pointer;
  text-align: left;
  font-family: var(--fu);
  font-size: 16px;
  font-weight: 700;
  color: var(--black);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color 0.2s;
  outline: 2px solid transparent !important;
  outline-offset: 4px !important;
}

.tr-product-page .tr-pp-accordion-trigger:hover,
.tr-product-page .tr-pp-accordion-trigger:focus,
body .tr-product-page button.tr-pp-accordion-trigger:hover,
body .tr-product-page button.tr-pp-accordion-trigger:focus {
  color: var(--forest);
  background: none !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.tr-product-page .tr-pp-accordion-trigger:focus-visible,
body .tr-product-page button.tr-pp-accordion-trigger:focus-visible {
  outline-color: #0F5E41 !important;
  box-shadow: 0 0 0 4px rgba(15, 94, 65, 0.14) !important;
}

.tr-product-page .tr-pp-accordion-trigger svg {
  width: 20px;
  height: 20px;
  color: var(--medium);
  flex-shrink: 0;
  transition: transform 0.3s ease;
}

.tr-product-page .tr-pp-accordion-item.open .tr-pp-accordion-trigger svg {
  transform: rotate(180deg);
}

.tr-product-page .tr-pp-accordion-item.open .tr-pp-accordion-trigger {
  color: var(--forest);
}

.tr-product-page .tr-pp-accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}

.tr-product-page .tr-pp-accordion-item.open .tr-pp-accordion-content {
  max-height: 3000px;
}

.tr-product-page .tr-pp-accordion-inner {
  padding: 0 0 24px;
}

.tr-product-page .tr-pp-accordion-inner p {
  font-size: 15px;
  line-height: 1.8;
  color: var(--secondary);
  margin-bottom: 14px;
}

.tr-product-page .tr-pp-accordion-inner p:last-child {
  margin-bottom: 0;
}

/* Video / fallback photo column */
.tr-product-page .tr-pp-video-column {
  position: sticky;
  top: 24px;
}

/* Fallback photo (when no video) */
.tr-product-page .tr-pp-fallback-photo {
  width: 100%;
  height: auto;
  border-radius: 20px;
  object-fit: cover;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.tr-product-page .tr-pp-video-column h2 {
  font-family: var(--fd);
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 700;
  color: var(--black);
  margin-bottom: 20px;
  line-height: 1.2;
}

.tr-product-page .tr-pp-video-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  border-radius: 20px;
  overflow: hidden;
  background: #eeeeee;
  cursor: pointer;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.tr-product-page .tr-pp-video-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tr-product-page .tr-pp-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--forest);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 3px solid rgba(255, 255, 255, 0.9);
  transition: transform 0.25s ease, background 0.2s;
}

.tr-product-page .tr-pp-video-wrap:hover .tr-pp-play-btn {
  transform: translate(-50%, -50%) scale(1.1);
  background: #0F5E41;
}

.tr-product-page .tr-pp-play-btn svg {
  width: 22px;
  height: 22px;
  color: var(--white);
  margin-left: 3px;
}


/* ============================================
   RELATED PRODUCTS
   ============================================ */
.tr-product-page .tr-pp-related-section {
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 48px) clamp(56px, 8vw, 80px);
}

/* Style the shortcode output (WooCommerce product grid) */
.tr-product-page .tr-pp-related-section ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(16px, 2.5vw, 28px);
  margin-top: 28px;
  list-style: none;
  padding: 0;
}

.tr-product-page .tr-pp-related-section ul.products li.product {
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.tr-product-page .tr-pp-related-section ul.products li.product:hover {
  transform: translateY(-3px);
}

.tr-product-page .tr-pp-related-section ul.products li.product a img {
  aspect-ratio: 1;
  background: #eeeeee;
  overflow: hidden;
  border-radius: 16px;
  width: 100%;
  height: auto;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.tr-product-page .tr-pp-related-section ul.products li.product:hover a img {
  transform: scale(1.03);
}

.tr-product-page .tr-pp-related-section ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--fu) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--black) !important;
  margin-top: 14px !important;
  line-height: 1.3 !important;
  transition: color 0.2s;
  text-transform: none !important;
}

.tr-product-page .tr-pp-related-section ul.products li.product:hover .woocommerce-loop-product__title {
  color: var(--forest) !important;
}

.tr-product-page .tr-pp-related-section ul.products li.product .price {
  font-family: var(--fu) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--forest) !important;
  margin-top: 4px !important;
}

/* Hide add-to-cart buttons in related grid */
.tr-product-page .tr-pp-related-section ul.products li.product .button,
.tr-product-page .tr-pp-related-section ul.products li.product .add_to_cart_button {
  display: none !important;
}

/* Hide badges and star ratings in related grid */
.tr-product-page .tr-pp-related-section ul.products li.product .tr-status-badge-wrap {
  display: none !important;
}

.tr-product-page .tr-pp-related-section ul.products li.product .star-rating {
  display: none !important;
}

/* Extra insurance: catch any title element Kadence might use */
.tr-product-page .tr-pp-related-section ul.products li.product h2,
.tr-product-page .tr-pp-related-section ul.products li.product h3,
.tr-product-page .tr-pp-related-section ul.products li.product .woocommerce-loop-product__title,
.tr-product-page .tr-pp-related-section .woocommerce-loop-product__title {
  text-transform: none !important;
}


/* ============================================
   REVIEWS — Matches Layout 17 Prototype EXACTLY
   2-Column: Reviews Left, Form Right
   NO cards, NO background, NO box-shadow on reviews
   ============================================ */
.tr-product-page .tr-pp-reviews-section {
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 48px) clamp(56px, 8vw, 80px);
}

.tr-product-page .tr-pp-reviews-section .tr-pp-section-heading {
  margin-bottom: 32px;
}

.tr-product-page .tr-pp-reviews-native {
  font-family: var(--fb);
  max-width: 1300px;
  margin: 0 auto;
}

/* Two-column layout: 1fr 1fr (prototype) */
.tr-product-page .tr-pp-reviews-native .woocommerce-Reviews,
body .woocommerce .tr-pp-reviews-native .woocommerce-Reviews,
body.single-product .tr-pp-reviews-native .woocommerce-Reviews {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: clamp(40px, 5vw, 72px) !important;
  width: 100% !important;
  float: none !important;
  align-items: start !important;
}

/* LEFT column: comments/reviews */
.tr-product-page .tr-pp-reviews-native .woocommerce-Reviews > #comments {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  flex: none !important;
  grid-column: 1 / 2 !important;
  padding: 0 !important;
}

/* RIGHT column: review form */
.tr-product-page .tr-pp-reviews-native .woocommerce-Reviews > #review_form_wrapper {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  flex: none !important;
  grid-column: 2 / 3 !important;
  padding: 32px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 20px !important;
  box-sizing: border-box !important;
}

/* Hide Kadence "X reviews for Product" title */
.tr-product-page .tr-pp-reviews-native .woocommerce-Reviews-title {
  display: none !important;
}

/* ---- Rating Overview — HIDDEN ---- */
.tr-product-page .tr-pp-reviews-native #kt-reviews-overview {
  display: none !important;
}

/* ---- Individual Reviews: NO cards, border-separated ---- */

/* Kill Kadence avatar float */
.tr-product-page .tr-pp-reviews-native #reviews #comments ol.commentlist li img.avatar {
  display: none !important;
}

.tr-product-page .tr-pp-reviews-native #reviews #comments ol.commentlist li .comment-text {
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

/* Review list: simple stack, NO grid, NO cards */
.tr-product-page .tr-pp-reviews-native .commentlist {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: block !important;
}

/* Each review: simple padding, separated by thin border. NO card. */
.tr-product-page .tr-pp-reviews-native .commentlist li {
  background: transparent !important;
  border-radius: 0 !important;
  padding: 24px 0 !important;
  box-shadow: none !important;
  border: none !important;
  border-bottom: none !important;
  position: relative !important;
  margin: 0 !important;
  list-style: none !important;
  transition: none !important;
}

.tr-product-page .tr-pp-reviews-native .commentlist li:first-child {
  padding-top: 0 !important;
}

.tr-product-page .tr-pp-reviews-native .commentlist li + li {
  border-top: 1px solid #E6E0D6 !important;
}

.tr-product-page .tr-pp-reviews-native .commentlist li:hover {
  transform: none !important;
  box-shadow: none !important;
  border-color: #E6E0D6 !important;
}

/* Comment container: just the text, no avatar */
.tr-product-page .tr-pp-reviews-native .comment_container {
  display: block !important;
}

/* Name + date row */
.tr-product-page .tr-pp-reviews-native .comment-text {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
}

.tr-product-page .tr-pp-reviews-native .comment-text .meta {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin: 0 0 6px 0 !important;
  padding: 0 !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  order: 1 !important;
}

/* Hide the dash between name and date */
.tr-product-page .tr-pp-reviews-native .comment-text .meta em {
  display: none !important;
}

.tr-product-page .tr-pp-reviews-native .comment-text .meta strong {
  font-family: var(--fu) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--black) !important;
}

.tr-product-page .tr-pp-reviews-native .comment-text .meta time {
  display: inline !important;
  font-family: var(--fu) !important;
  font-size: 15px !important;
  color: var(--black) !important;
  margin: 0 !important;
}

/* Stars below name */
.tr-product-page .tr-pp-reviews-native .comment-text .star-rating {
  display: flex !important;
  margin: 0 0 8px 0 !important;
  float: none !important;
  font-size: 16px !important;
  color: var(--star) !important;
  order: 2 !important;
}

.tr-product-page .tr-pp-reviews-native .comment-text .star-rating::before {
  color: var(--star) !important;
}

/* Review body */
.tr-product-page .tr-pp-reviews-native .comment-text .description {
  margin-top: 0 !important;
  order: 3 !important;
}

.tr-product-page .tr-pp-reviews-native .comment-text .description p {
  font-size: 15px !important;
  line-height: 1.7 !important;
  color: var(--black) !important;
  margin: 0 !important;
}

/* Hide Kadence overlay */
.tr-product-page .tr-pp-reviews-native .kt-review-overlay {
  display: none !important;
}

/* ---- Load More Reviews button ---- */
.tr-product-page .tr-pp-reviews-native .kt-ajax-load-more-reviews-container {
  text-align: center;
  margin-top: 32px;
}

.tr-product-page .tr-pp-reviews-native button.kt-ajax-load-more-reviews,
body .tr-product-page button.kt-ajax-load-more-reviews {
  background: var(--forest) !important;
  color: #ffffff !important;
  font-family: var(--fu) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  padding: 12px 32px !important;
  border: none !important;
  border-radius: 100px !important;
  cursor: pointer !important;
  transition: background 0.2s, transform 0.2s !important;
  min-height: 48px !important;
}

.tr-product-page .tr-pp-reviews-native button.kt-ajax-load-more-reviews:hover,
body .tr-product-page button.kt-ajax-load-more-reviews:hover {
  background: #0F5E41 !important;
  transform: translateY(-1px) !important;
}

/* ---- Review Form: bordered container, matches prototype ---- */
.tr-product-page .tr-pp-reviews-native #review_form_wrapper {
  background: transparent !important;
  border-radius: 20px !important;
  padding: 32px !important;
  margin-top: 0 !important;
  box-shadow: none !important;
  border: 1.5px solid var(--border) !important;
  box-sizing: border-box !important;
  clear: none !important;
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Form heading */
.tr-product-page .tr-pp-reviews-native #review_form_wrapper h3,
.tr-product-page .tr-pp-reviews-native #reply-title,
.tr-product-page .tr-pp-reviews-native .comment-reply-title {
  font-family: var(--fd) !important;
  color: var(--black) !important;
  font-size: clamp(22px, 3vw, 28px) !important;
  margin-bottom: 24px !important;
  font-weight: 700 !important;
}

/* Form labels */
.tr-product-page .tr-pp-reviews-native .comment-form label {
  font-family: var(--fu) !important;
  color: var(--black) !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  display: block !important;
  margin-bottom: 6px !important;
}

/* Form inputs + textarea */
.tr-product-page .tr-pp-reviews-native .comment-form textarea,
.tr-product-page .tr-pp-reviews-native .comment-form input[type="text"],
.tr-product-page .tr-pp-reviews-native .comment-form input[type="email"],
.tr-product-page .tr-pp-reviews-native .comment-form select {
  font-family: var(--fb) !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 12px 14px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 10px !important;
  font-size: 15px !important;
  color: var(--black) !important;
  background: var(--white) !important;
  transition: border-color 0.2s !important;
  box-sizing: border-box !important;
}

.tr-product-page .tr-pp-reviews-native #reviews #comment {
  height: auto !important;
  min-height: 120px !important;
  max-height: 180px !important;
  resize: vertical !important;
}

.tr-product-page .tr-pp-reviews-native .comment-form textarea:focus,
.tr-product-page .tr-pp-reviews-native .comment-form input[type="text"]:focus,
.tr-product-page .tr-pp-reviews-native .comment-form input[type="email"]:focus {
  border-color: var(--forest) !important;
  outline: 2px solid rgba(15, 94, 65, 0.35) !important;
  outline-offset: 2px !important;
}

/* Star rating picker */
.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars {
  margin: 10px 0 16px 0 !important;
  display: inline-flex !important;
  gap: 4px !important;
}

.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars a {
  color: #E6E0D6 !important;
  font-size: 28px !important;
  transition: color 0.15s !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

/* Hover: all stars up to and including hovered one go gold */
.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars a:hover,
.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars a:hover ~ a {
  color: #E6E0D6 !important;
}

.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars:hover a {
  color: var(--star) !important;
}

.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars a:hover ~ a {
  color: #E6E0D6 !important;
}

/* Selected state: WooCommerce adds .active on the chosen star */
.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars.selected a {
  color: var(--star) !important;
}

.tr-product-page .tr-pp-reviews-native .comment-form-rating .stars.selected a.active ~ a {
  color: #E6E0D6 !important;
}

/* Privacy consent — push to bottom via order */
.tr-product-page .tr-pp-reviews-native .comment-form-consent {
  margin: 18px 0 !important;
  order: 90 !important;
}

.tr-product-page .tr-pp-reviews-native .comment-form-consent input[type="checkbox"] {
  margin-right: 8px !important;
  accent-color: var(--forest) !important;
}

.tr-product-page .tr-pp-reviews-native .comment-form-consent label {
  font-weight: 400 !important;
  display: inline !important;
  font-size: 14px !important;
}

/* Form row spacing */
.tr-product-page .tr-pp-reviews-native #review_form_wrapper #respond p {
  margin: 0 0 16px !important;
}

/* Prevent form overflow */
.tr-product-page .tr-pp-reviews-native #review_form #respond {
  position: static !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-sizing: border-box !important;
}

.tr-product-page .tr-pp-reviews-native #review_form #respond form {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Push submit to end */
.tr-product-page .tr-pp-reviews-native .form-submit {
  order: 99 !important;
}

/* Submit button — full-width pill matching prototype */
.tr-product-page .tr-pp-reviews-native .form-submit input[type="submit"],
.tr-product-page .tr-pp-reviews-native #submit {
  background: var(--forest) !important;
  color: #ffffff !important;
  font-family: var(--fu) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  padding: 14px 32px !important;
  border: none !important;
  border-radius: 100px !important;
  cursor: pointer !important;
  transition: background 0.2s, transform 0.2s !important;
  min-height: 48px !important;
  margin-top: 8px !important;
  width: 100% !important;
  display: block !important;
  text-align: center !important;
}

.tr-product-page .tr-pp-reviews-native .form-submit input[type="submit"]:hover,
.tr-product-page .tr-pp-reviews-native #submit:hover {
  background: #0F5E41 !important;
  transform: translateY(-1px) !important;
}

/* ---- Reviews responsive ---- */
@media (max-width: 900px) {
  .tr-product-page .tr-pp-reviews-native .woocommerce-Reviews,
  body .woocommerce .tr-pp-reviews-native .woocommerce-Reviews,
  body.single-product .tr-pp-reviews-native .woocommerce-Reviews {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  .tr-product-page .tr-pp-reviews-native .woocommerce-Reviews > #comments,
  .tr-product-page .tr-pp-reviews-native .woocommerce-Reviews > #review_form_wrapper {
    grid-column: 1 / -1 !important;
    position: static !important;
  }

  .tr-product-page .tr-pp-reviews-native #review_form_wrapper {
    padding: 24px !important;
  }
}

@media (max-width: 500px) {
  .tr-product-page .tr-pp-reviews-native #review_form_wrapper {
    padding: 20px 18px !important;
  }
}


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

.tr-product-page .scroll-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

.tr-product-page .scroll-reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .tr-product-page .tr-pp-gallery,
  .tr-product-page .tr-pp-product-info {
    opacity: 1;
    animation: none;
    transform: none;
  }

  .tr-product-page .scroll-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}


/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 900px) {
  .tr-product-page .tr-pp-hero {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .tr-product-page .tr-pp-closer-body {
    grid-template-columns: 1fr;
  }

  .tr-product-page .tr-pp-details-video {
    grid-template-columns: 1fr;
  }

  .tr-product-page .tr-pp-video-column {
    position: static;
  }

  .tr-product-page .tr-pp-related-section ul.products {
    grid-template-columns: 1fr 1fr;
  }

  /* Reviews — native Kadence Shop Kit handles responsive */
}

@media (max-width: 600px) {
  .tr-product-page .tr-pp-related-section ul.products {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
}

@media (max-width: 500px) {
  .tr-product-page .tr-pp-hero {
    display: block;
  }

  .tr-product-page .tr-pp-fun-bits {
    flex-direction: column;
    gap: 8px;
  }

  .tr-product-page .tr-pp-fun-bit-divider {
    display: none;
  }

  .tr-product-page .tr-pp-purchase form.cart,
  .tr-product-page .tr-pp-purchase .kwt-add-to-cart-wrap .cart {
    flex-direction: column;
    align-items: stretch;
  }

  .tr-product-page .tr-pp-purchase .single_add_to_cart_button {
    justify-content: center !important;
    width: 100% !important;
    margin-top: 12px !important;
  }

  .tr-product-page .tr-pp-reviews-native .woocommerce-Reviews,
  body .woocommerce .tr-pp-reviews-native .woocommerce-Reviews,
  body.single-product .tr-pp-reviews-native .woocommerce-Reviews {
    display: block !important;
  }

  .tr-product-page .tr-pp-reviews-native #review_form_wrapper {
    margin-top: 24px !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  .tr-product-page .tr-pp-reviews-native #review_form_wrapper .cf-turnstile {
    transform: scale(0.85) !important;
    transform-origin: left top !important;
  }

  .tr-product-page .tr-pp-related-section ul.products {
    grid-template-columns: 1fr;
  }
}
