/* =========================================================
   POLYDIGM BILLIARDS - PRODUCT CSS
   Load only on single product pages.
   Depends on 00-polydigm-global.css.
   ========================================================= */

/* =========================================================
   5. SINGLE PRODUCT LAYOUT
   ========================================================= */

.single-product main#main,
.single-product .content-area,
.single-product .site-main {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.single-product .site-content .ast-container {
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

.woocommerce div.product {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 48px;
  align-items: start !important;
  min-height: auto !important;
}

.woocommerce div.product div.images,
.woocommerce div.product div.summary {
  float: none !important;
  width: 100% !important;
}


/* Product image box */
.woocommerce div.product div.images {
  position: relative;
  background: var(--pd-bg);
  border: 1px solid var(--pd-border);
  border-radius: var(--pd-radius);
  padding: 18px;
  overflow: hidden;
}

.woocommerce div.product div.images img {
  background: var(--pd-bg) !important;
  border-radius: 16px;
  object-fit: contain;
}


/* Intro price badge */
.onsale,
span.onsale,
a.onsale,
.woocommerce .onsale,
.woocommerce-page .onsale,
.single-product .onsale,
ul.products li.product .onsale,
.related .onsale,
.up-sells .onsale {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.woocommerce div.product div.images::before {
  content: "INTRODUCTORY PRICE";
  position: absolute;
  top: 26px;
  left: 26px;
  z-index: 50;
  padding: 16px 26px;
  background: rgba(255,255,255,0.97);
  color: #050505;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1;
  box-shadow:
    0 12px 28px rgba(0,0,0,0.34),
    0 0 22px rgba(255,255,255,0.16);
}


/* Product summary card */
.woocommerce div.product div.summary {
  margin: 0 !important;
  padding: 34px 34px 24px !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(245,196,0,0.16), transparent 30%),
    radial-gradient(circle at 100% 100%, rgba(255,255,255,0.045), transparent 34%),
    linear-gradient(180deg, #151515, #060606);
  border: 1px solid rgba(245,196,0,0.22);
  border-radius: 28px;
  box-shadow:
    0 28px 90px rgba(0,0,0,0.72),
    inset 0 1px 0 rgba(255,255,255,0.07),
    0 0 42px rgba(245,196,0,0.08);
}


/* Hide Woo clutter */
.woocommerce-breadcrumb,
.ast-breadcrumbs-wrapper,
.woocommerce div.product .summary > .posted_in,
.woocommerce div.product div.summary > a,
.woocommerce div.product div.summary .posted_in,
.woocommerce div.product div.summary .sku_wrapper,
.woocommerce div.product div.summary .tagged_as,
.product_meta {
  display: none !important;
}


/* Title / price / short description */
.woocommerce div.product .product_title {
  font-size: clamp(2.35rem, 4vw, 3.4rem);
  font-weight: 950;
  line-height: 0.95;
  margin: 10px 0 18px;
  color: #fff !important;
  text-shadow:
    3px 3px 0 rgba(245,196,0,0.18),
    0 0 28px rgba(255,255,255,0.10);
}

.woocommerce div.product p.price {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 22px;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--pd-yellow) !important;
  font-size: 1.75rem;
  font-weight: 950;
}

.woocommerce div.product p.price del {
  color: rgba(255,255,255,0.23) !important;
  font-size: 1.35rem;
}

.woocommerce div.product p.price ins {
  color: var(--pd-yellow) !important;
  text-decoration: none;
}

.woocommerce-product-details__short-description {
  max-width: 560px;
  margin-bottom: 14px !important;
  color: rgba(255,255,255,0.9);
  font-size: 1rem;
  line-height: 1.72;
}

.woocommerce-product-details__short-description p {
  margin-bottom: 1.25em;
}

.woocommerce-product-details__short-description p:last-child {
  margin-top: 22px;
  margin-bottom: 8px !important;
  padding-left: 16px;
  border-left: 3px solid var(--pd-yellow);
  font-weight: 800;
}


/* =========================================================
   6. PRODUCT DUROMETER SELECTOR
   ========================================================= */

.woocommerce div.product form.cart {
  margin-top: 10px !important;
  padding-top: 0 !important;
  border-top: 0 !important;
}

.woocommerce div.product form.cart .variations {
  margin: 12px 0 14px !important;
  padding: 14px 18px 12px !important;
  background:
    radial-gradient(circle at top left, rgba(245,196,0,0.10), transparent 38%),
    linear-gradient(180deg, #111111, #070707);
  border: 1px solid rgba(245,196,0,0.18) !important;
  border-radius: 24px;
  box-shadow:
    0 18px 50px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

.woocommerce div.product form.cart table.variations,
.woocommerce div.product form.cart .variations tbody,
.woocommerce div.product form.cart .variations tr,
.woocommerce div.product form.cart .variations th,
.woocommerce div.product form.cart .variations td {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  text-align: center;
  vertical-align: middle !important;
}

.woocommerce div.product form.cart .variations th.label {
  padding: 0 0 6px 0 !important;
}

.woocommerce div.product form.cart .variations td.value {
  padding: 0 !important;
}

.woocommerce div.product form.cart .variations select,
.reset_variations {
  display: none !important;
}

.woocommerce div.product form.cart .variations label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0 0 8px !important;
  color: #fff !important;
  font-size: 1.08rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  line-height: 1;
  text-shadow: 0 0 18px rgba(245,196,0,0.18);
}

.woocommerce div.product form.cart .variations label::before {
  content: "";
  display: block;
  width: 6px;
  height: 18px;
  border-radius: 999px;
  background: var(--pd-yellow);
  box-shadow: 0 0 18px rgba(245,196,0,0.45);
}

.pd-pill-group {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 8px 10px !important;
  max-width: 410px !important;
  margin: 6px auto 10px !important;
}

.pd-pill,
button.pd-pill,
.woocommerce button.pd-pill,
.woocommerce-page button.pd-pill {
  appearance: none !important;
  width: auto !important;
  min-width: 64px !important;
  min-height: 34px !important;
  flex: 0 0 auto !important;
  padding: 7px 11px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,0.16) !important;
  background: linear-gradient(180deg, #151515, #080808) !important;
  color: rgba(255,255,255,0.78) !important;
  font-size: 0.70rem !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06) !important;
  transition:
    transform 0.14s ease,
    border-color 0.14s ease,
    box-shadow 0.14s ease,
    background 0.14s ease,
    color 0.14s ease !important;
}

/* Durometer color map */
button.pd-pill[data-value*="75"]   { --pill: #49b6ff; }
button.pd-pill[data-value*="77"]   { --pill: #7b1e3a; }
button.pd-pill[data-value*="80"]   { --pill: #ffd400; }
button.pd-pill[data-value*="82"]   { --pill: #ff4fb3; }
button.pd-pill[data-value*="85"]   { --pill: #7d5cff; }
button.pd-pill[data-value*="87"]   { --pill: #8a8a8a; }
button.pd-pill[data-value*="90"]   { --pill: #006c5f; }
button.pd-pill[data-value*="92"]   { --pill: #2257ff; }
button.pd-pill[data-value*="95"]   { --pill: #95ff1f; }
button.pd-pill[data-value*="97"]   { --pill: #ff7a00; }
button.pd-pill[data-value*="100"]  { --pill: #ff3131; }

button.pd-pill:hover,
.woocommerce button.pd-pill:hover,
.woocommerce-page button.pd-pill:hover {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--pill) 28%, #080808) !important;
  color: #fff !important;
  border-color: var(--pill) !important;
  box-shadow:
    0 0 18px color-mix(in srgb, var(--pill) 55%, transparent),
    inset 0 1px 0 rgba(255,255,255,0.10) !important;
}

button.pd-pill.active,
.woocommerce button.pd-pill.active,
.woocommerce-page button.pd-pill.active {
  transform: translateY(-1px) scale(1.04);
  background: var(--pill) !important;
  border-color: var(--pill) !important;
  box-shadow:
    0 0 24px color-mix(in srgb, var(--pill) 75%, transparent),
    0 0 52px color-mix(in srgb, var(--pill) 36%, transparent) !important;
}

button.pd-pill:focus,
.woocommerce button.pd-pill:focus,
.woocommerce-page button.pd-pill:focus {
  outline: none !important;
}

button.pd-pill[data-value*="75"].active,
button.pd-pill[data-value*="80"].active,
button.pd-pill[data-value*="82"].active,
button.pd-pill[data-value*="87"].active,
button.pd-pill[data-value*="95"].active,
button.pd-pill[data-value*="97"].active {
  color: #050505 !important;
}

button.pd-pill[data-value*="77"].active,
button.pd-pill[data-value*="85"].active,
button.pd-pill[data-value*="90"].active,
button.pd-pill[data-value*="92"].active,
button.pd-pill[data-value*="100"].active {
  color: #fff !important;
}


/* Availability / cart row locked */
.woocommerce div.product form.cart .single_variation_wrap {
  height: 128px !important;
  min-height: 128px !important;
  max-height: 128px !important;
  margin-top: 8px !important;
  overflow: visible !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
}

.woocommerce-variation.single_variation {
  height: 58px !important;
  min-height: 58px !important;
  max-height: 58px !important;
  margin: 8px 0 !important;
  overflow: visible !important;
}

.woocommerce-variation-availability {
  height: 58px !important;
  min-height: 58px !important;
  max-height: 58px !important;
  margin: 0 !important;
  display: block !important;
}

.woocommerce-variation-availability .stock::before {
  content: none !important;
  display: none !important;
}

.woocommerce-variation-availability .stock {
  margin: 0 !important;
  padding: 0 !important;
  height: 58px !important;
  min-height: 58px !important;
  line-height: 1.45 !important;
  font-size: 0.9rem !important;
  font-weight: 900 !important;
}

.woocommerce-variation-availability .stock.in-stock {
  color: var(--pd-green) !important;
  text-shadow: 0 0 12px rgba(99,214,95,0.22);
}

.woocommerce-variation-availability .stock.out-of-stock {
  color: var(--pd-red) !important;
  text-shadow: 0 0 14px rgba(255,49,49,0.32);
}

.woocommerce-variation-add-to-cart {
  height: 54px !important;
  min-height: 54px !important;
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}

.woocommerce .quantity .qty {
  width: 64px;
  min-height: 48px;
  text-align: center;
  border-radius: 14px !important;
  font-weight: 800;
}

.woocommerce div.product form.cart .button {
  min-height: 48px;
  padding: 0 28px !important;
  margin-left: 12px;
}

.single-product #wc-stripe-payment-request-wrapper,
.single-product #wc-stripe-payment-request-button-separator {
  display: none !important;
}


/* =========================================================
   7. PRODUCT TABS / DESCRIPTION / HARDNESS GUIDE
   ========================================================= */

.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1;
  margin-top: -25px !important;
  padding: 18px 34px 26px !important;
  background:
    radial-gradient(circle at top left, rgba(245,196,0,0.10), transparent 28%),
    linear-gradient(180deg, #101010, #050505);
  border: 1px solid rgba(245,196,0,0.16);
  border-radius: 28px;
  box-shadow:
    0 26px 80px rgba(0,0,0,0.58),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0 !important;
  margin: 0 0 18px 0 !important;
  border: 0 !important;
}

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

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: linear-gradient(180deg, #171717, #070707) !important;
  border: 1px solid rgba(255,255,255,0.16) !important;
  border-radius: 999px !important;
  margin: 0 10px 10px 0 !important;
  padding: 0 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  color: #fff !important;
  padding: 11px 18px !important;
  font-weight: 950 !important;
  letter-spacing: 0.01em;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  background: var(--pd-yellow) !important;
  border-color: var(--pd-yellow) !important;
  box-shadow:
    0 0 24px rgba(245,196,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: #050505 !important;
}

.woocommerce-Tabs-panel {
  max-width: none;
  color: var(--pd-text);
  line-height: 1.75;
}

.woocommerce-Tabs-panel em {
  display: inline-block;
  margin: 28px 0 24px 52px;
  padding: 18px 24px;
  color: #fff;
  font-size: 1.18rem;
  font-weight: 850;
  font-style: italic;
  border-left: 3px solid var(--pd-yellow);
  background: rgba(255,255,255,0.035);
  border-radius: 0 16px 16px 0;
}


/* Description tab custom HTML */
.pd-story-content {
  max-width: 980px;
}

.pd-kicker {
  color: var(--pd-yellow) !important;
  font-size: 0.78rem !important;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-bottom: 10px;
}

.pd-story-content h2 {
  color: #fff !important;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 0.95;
  margin-top: 0 !important;
  margin-bottom: 22px;
  text-shadow: 3px 3px 0 rgba(245,196,0,0.16);
}

.pd-lead {
  max-width: 820px;
  color: rgba(255,255,255,0.88) !important;
  font-size: 1.18rem !important;
  line-height: 1.75;
}

.pd-story-content p {
  margin-top: 0 !important;
  color: rgba(255,255,255,0.82) !important;
  font-size: 1rem;
  line-height: 1.75;
}

.pd-pullquote {
  margin: 28px 0 24px;
  padding: 24px 28px;
  background: rgba(245,196,0,0.08);
  border-left: 4px solid var(--pd-yellow);
  border-radius: 0 18px 18px 0;
  color: #fff;
  font-size: clamp(1.25rem, 2vw, 1.65rem);
  font-weight: 850;
  font-style: italic;
}

.pd-story-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin: 24px 0 20px;
}

.pd-story-grid > div,
.pd-statement,
.pd-hardness-card {
  background:
    radial-gradient(circle at top left, rgba(245,196,0,0.10), transparent 38%),
    linear-gradient(180deg, #151515, #070707);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 20px;
}

.pd-story-grid > div {
  padding: 20px 24px;
}

.pd-story-grid h3 {
  color: var(--pd-yellow) !important;
  font-size: 1.35rem;
  line-height: 1.1;
  margin-top: 0 !important;
  margin-bottom: 14px !important;
}

.pd-story-grid p {
  margin: 0 !important;
}

.pd-statement {
  margin: 20px 0 24px;
  padding: 18px 26px;
  border-color: rgba(245,196,0,0.28);
}

.pd-statement strong {
  display: block;
  color: var(--pd-yellow);
  font-size: 1.25rem;
  line-height: 1.15;
  margin: 0 0 6px !important;
}

.pd-statement span {
  display: block;
  color: #fff;
  font-size: 1rem;
  line-height: 1.5;
}

.pd-story-content > p:last-child {
  margin-bottom: 0;
}


/* Hardness guide tab */
.pd-hardness-guide {
  max-width: 1120px;
}

.pd-hardness-intro {
  max-width: 860px;
  color: rgba(255,255,255,0.76);
  font-size: 1.04rem;
  line-height: 1.75;
  margin-bottom: 28px;
}

.pd-hardness-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.pd-hardness-card {
  position: relative;
  overflow: hidden;
  padding: 24px;
  border-radius: 22px;
  box-shadow:
    0 20px 60px rgba(0,0,0,0.48),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.pd-hardness-card h3 {
  color: var(--pd-yellow) !important;
  font-size: 1.45rem;
  letter-spacing: -0.04em;
  margin-bottom: 12px;
}

.pd-hardness-card strong {
  display: block;
  color: #fff;
  font-size: 1rem;
  line-height: 1.45;
  margin-bottom: 14px;
}

.pd-hardness-card p {
  color: rgba(255,255,255,0.86);
  font-size: 0.94rem;
  line-height: 1.72;
}

.pd-hardness-card span {
  display: block;
  margin-top: 20px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.11);
  color: rgba(255,255,255,0.42);
  font-size: 0.8rem;
  line-height: 1.6;
}

/* Product page: center image card vertically against summary card */
.single-product .woocommerce div.product {
  align-items: center !important;
}

/* Keep tabs overlap/spacing as previously tuned */
.single-product .woocommerce div.product .woocommerce-tabs {
  margin-top: -25px !important;
}

@media (max-width: 921px) {
  .woocommerce div.product {
    display: block;
  }

  .woocommerce div.product div.images {
    margin-bottom: 28px !important;
  }

  .single-product .site-content .ast-container {
    padding-top: 24px !important;
  }

  .woocommerce div.product div.summary,
  .woocommerce div.product .woocommerce-tabs {
    padding: 24px !important;
  }

  .pd-hardness-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .pd-story-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 544px) {
  .woocommerce div.product .product_title {
    font-size: 2.25rem;
  }

  .woocommerce div.product .woocommerce-tabs ul.tabs li {
    display: inline-block !important;
  }

  .pd-hardness-grid {
    grid-template-columns: 1fr;
  }

  .woocommerce-Tabs-panel em {
    margin-left: 0;
  }

  .woocommerce div.product div.images::before {
    top: 18px;
    left: 18px;
    padding: 13px 18px;
    font-size: 0.68rem;
  }
}
