/* ==========================================
   SINGLE PRODUCT PAGE
   ========================================== */

/* Reduced top padding so the gallery sits close to the header */
.woo-wrap { padding-top: var(--sp-5); padding-bottom: var(--sp-16); }
@media (max-width: 720px) { .woo-wrap { padding-top: var(--sp-3); padding-bottom: var(--sp-10); } }

/* Two-column grid; explicit placement so tabs/related span the full width */
.single-product .product {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: clamp(32px, 5vw, 80px) clamp(40px, 5vw, 80px);
  align-items: start;
}

.single-product .product > .images,
.single-product .product .woocommerce-product-gallery {
  grid-column: 1 / 2;
  grid-row: 1 / 2;
}
.single-product .product > .summary {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}
.single-product .product > .woocommerce-tabs,
.single-product .product > .related,
.single-product .product > .up-sells {
  grid-column: 1 / -1;
}

/* Stop right-side related products spilling into the summary column */
.single-product .related.products,
.single-product .up-sells.products {
  grid-column: 1 / -1;
  width: 100%;
}

@media (max-width: 880px) {
  .single-product .product {
    display: block; /* Stack everything vertically — kill the desktop grid */
  }
  .single-product .product > .images,
  .single-product .product > .summary,
  .single-product .product > .woocommerce-tabs,
  .single-product .product > .related,
  .single-product .product > .up-sells,
  .single-product .product .woocommerce-product-gallery {
    width: 100%;
    margin-bottom: var(--sp-6);
  }
  .single-product .product > .summary { margin-top: var(--sp-2); }
  .single-product .product > .woocommerce-tabs { margin-top: var(--sp-8); }
  .single-product .product > .related { margin-top: var(--sp-10); }
}

/* ==========================================
   PRODUCT GALLERY (custom horizontal carousel)
   ========================================== */
.pgallery {
  position: relative;
  width: 100%;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--c-bg-cream);
}

.pgallery__viewport {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}
.pgallery__viewport::-webkit-scrollbar { display: none; }

.pgallery__slide {
  flex: 0 0 100%;
  min-width: 0;
  margin: 0;
  scroll-snap-align: start;
  scroll-snap-stop: always;
}
.pgallery__slide img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center;
  cursor: default;
}

/* Arrows */
.pgallery__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.85);
  color: var(--c-ink);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 2px 12px rgba(10,10,10,0.10);
  transition: background var(--t-fast), opacity var(--t-fast), transform var(--t-fast);
  z-index: 2;
  opacity: 0;
}
.pgallery:hover .pgallery__btn { opacity: 1; }
.pgallery__btn:hover { background: #fff; transform: translateY(-50%) scale(1.05); }
.pgallery__btn--prev { left: 12px; }
.pgallery__btn--next { right: 12px; }
.pgallery__btn:disabled { opacity: 0 !important; pointer-events: none; }

/* Always show on touch devices */
@media (hover: none) {
  .pgallery__btn { display: none; }
}

/* Photo counter (top-right) */
.pgallery__count {
  position: absolute;
  top: 12px; right: 12px;
  z-index: 2;
  background: rgba(10,10,10,0.7);
  color: #fff;
  font-size: 11px;
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  padding: 5px 10px;
  border-radius: 999px;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  font-variant-numeric: tabular-nums;
}

/* Dots indicator (bottom-center) */
.pgallery__dots {
  position: absolute;
  bottom: 12px;
  left: 0; right: 0;
  display: flex;
  justify-content: center;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
  z-index: 2;
}
.pgallery__dots button {
  width: 7px;
  height: 7px;
  padding: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.55);
  border: 0;
  cursor: pointer;
  transition: background var(--t-fast), width var(--t-fast);
}
.pgallery__dots button:hover { background: rgba(255,255,255,0.85); }
.pgallery__dots button[aria-current="true"] {
  background: #fff;
  width: 22px;
  border-radius: 999px;
}

/* Single-image: no nav, no dots, no count */
.pgallery--single .pgallery__btn,
.pgallery--single .pgallery__count,
.pgallery--single .pgallery__dots { display: none; }

/* Summary */
.summary.entry-summary {
  display: flex; flex-direction: column; gap: var(--sp-4);
}
.product_title.entry-title {
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 400; letter-spacing: var(--ls-tight); margin: 0; line-height: 1.15;
}
.single-product .price,
.summary .price { display: none; } /* hidden — bundle selector shows pricing */

.woocommerce-product-details__short-description {
  color: var(--c-muted); line-height: 1.65; font-size: var(--fs-base);
}
.woocommerce-product-details__short-description p:last-child { margin-bottom: 0; }

.product_meta { font-size: var(--fs-xs); color: var(--c-muted); padding-top: var(--sp-5); border-top: 1px solid var(--c-line-soft); }
.product_meta > span { display: block; margin-top: 4px; }

/* ==========================================
   SIZE PICKER
   ========================================== */
.size-picker {
  border: 0; padding: 0; margin: 0 0 var(--sp-2);
  display: flex; flex-direction: column; gap: var(--sp-3);
}
.size-picker__legend {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold); letter-spacing: var(--ls-extra);
  text-transform: uppercase; color: var(--c-muted);
  padding: 0;
}
.size-picker__legend > :first-child { color: var(--c-ink); }
.size-picker__hint {
  font-size: 11px; font-weight: var(--fw-medium);
  color: var(--c-muted); letter-spacing: var(--ls-wide);
  text-transform: none;
  font-style: italic;
}
.size-picker.is-selected .size-picker__hint { display: none; }
.size-picker.is-error { animation: size-shake 320ms cubic-bezier(.4,0,.2,1); }
.size-picker.is-error .size-opt__label {
  border-color: var(--c-danger);
}
.size-picker.is-error .size-picker__hint {
  color: var(--c-danger);
  font-weight: var(--fw-semibold);
  font-style: normal;
}
@keyframes size-shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-6px); }
  75% { transform: translateX(6px); }
}

.size-picker__opts {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-2);
}

.size-opt { position: relative; display: block; cursor: pointer; }
.size-opt input[type="radio"] {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  opacity: 0; cursor: pointer;
  margin: 0; padding: 0;
}
.size-opt__label {
  display: flex; align-items: center; justify-content: center;
  height: 56px;
  border: 1.5px solid var(--c-line);
  border-radius: var(--radius);
  background: var(--c-bg);
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
  color: var(--c-ink);
  transition: border-color var(--t), background var(--t), color var(--t), transform var(--t-fast);
  user-select: none;
}
.size-opt:hover .size-opt__label { border-color: var(--c-ink); transform: translateY(-1px); }
.size-opt input[type="radio"]:checked + .size-opt__label {
  background: var(--c-ink);
  border-color: var(--c-ink);
  color: var(--c-bg);
}
.size-opt input[type="radio"]:focus-visible + .size-opt__label {
  outline: 3px solid rgba(200,169,126,0.4);
  outline-offset: 2px;
}

@media (max-width: 480px) {
  .size-opt__label { height: 48px; font-size: var(--fs-base); }
  .size-picker__opts { gap: var(--sp-1); }
}

/* ==========================================
   BUNDLE PICKER (the conversion engine)
   ========================================== */
.bundle-form { display: flex; flex-direction: column; gap: var(--sp-5); }
.bundle-picker {
  border: 0; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--sp-3);
}
.bundle-picker__legend {
  font-size: var(--fs-xs); font-weight: var(--fw-semibold); letter-spacing: var(--ls-extra);
  text-transform: uppercase; color: var(--c-muted); margin-bottom: var(--sp-2);
}

.bundle-opt {
  position: relative; display: block; cursor: pointer;
}
.bundle-opt input[type="radio"] {
  position: absolute; opacity: 0; pointer-events: none;
}
.bundle-opt__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-6);
  border: 1.5px solid var(--c-line);
  border-radius: var(--radius);
  background: var(--c-bg);
  transition: border-color var(--t), background var(--t), transform var(--t-fast);
}
.bundle-opt:hover .bundle-opt__inner { border-color: var(--c-ink); }
.bundle-opt input[type="radio"]:focus-visible + .bundle-opt__inner {
  outline: 3px solid rgba(200,169,126,0.4); outline-offset: 2px;
}

.bundle-opt__inner::before {
  content: ""; display: inline-block; width: 20px; height: 20px;
  border: 2px solid var(--c-line); border-radius: 50%;
  background: var(--c-bg);
  transition: border-color var(--t), background var(--t);
  flex: 0 0 20px;
}
.bundle-opt.is-active .bundle-opt__inner,
.bundle-opt input[type="radio"]:checked + .bundle-opt__inner {
  border-color: var(--c-ink);
  background: var(--c-bg-cream);
}
.bundle-opt.is-active .bundle-opt__inner::before,
.bundle-opt input[type="radio"]:checked + .bundle-opt__inner::before {
  border-color: var(--c-ink);
  background: var(--c-ink);
  box-shadow: inset 0 0 0 4px var(--c-bg-cream);
}

.bundle-opt__head {
  display: inline-flex; align-items: baseline; gap: var(--sp-2);
}
.bundle-opt__qty {
  font-size: 32px; font-weight: 500; line-height: 1; letter-spacing: -0.02em;
}
.bundle-opt__lbl {
  font-size: var(--fs-sm); color: var(--c-muted);
}
.bundle-opt__price {
  font-size: var(--fs-xl); font-weight: var(--fw-medium); justify-self: end; line-height: 1;
}
.bundle-opt__per {
  grid-column: 2 / -1;
  font-size: var(--fs-xs); color: var(--c-muted); margin-top: 2px;
}
.bundle-opt__badge {
  position: absolute; top: -10px; right: var(--sp-5);
  background: var(--c-ink); color: var(--c-bg);
  font-size: 10px; letter-spacing: var(--ls-extra); text-transform: uppercase; font-weight: var(--fw-semibold);
  padding: 5px 10px; border-radius: 999px; z-index: 1;
}
.bundle-opt--best .bundle-opt__badge { background: var(--c-accent); color: #fff; }
.bundle-opt--best:hover .bundle-opt__inner { border-color: var(--c-accent); }
.bundle-opt--best.is-active .bundle-opt__inner,
.bundle-opt--best input[type="radio"]:checked + .bundle-opt__inner {
  border-color: var(--c-accent);
  background: linear-gradient(180deg, #FAF6EF, #FFFFFF);
}
.bundle-opt--best.is-active .bundle-opt__inner::before,
.bundle-opt--best input[type="radio"]:checked + .bundle-opt__inner::before {
  border-color: var(--c-accent); background: var(--c-accent); box-shadow: inset 0 0 0 4px #FAF6EF;
}

/* CTA */
.single_add_to_cart_button.btn {
  font-size: var(--fs-base);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  padding: 20px 28px;
}
.bundle-cta__price { font-weight: var(--fw-semibold); margin-left: 4px; }

/* Perks */
.bundle-perks {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-2);
  padding-top: var(--sp-5); border-top: 1px solid var(--c-line-soft); margin-top: var(--sp-3);
  list-style: none;
}
.bundle-perks li { font-size: var(--fs-sm); color: var(--c-ink-soft); }

/* ==========================================
   PRODUCT INFO — Size chart / composition / care
   Lightweight HTML <details> accordion
   ========================================== */
.prod-info {
  margin-top: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--c-line-soft);
}
.prod-info__item {
  border-bottom: 1px solid var(--c-line-soft);
}
.prod-info__item summary {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) 0;
  cursor: pointer;
  list-style: none;
  font-size: var(--fs-sm);
  color: var(--c-ink);
  user-select: none;
  transition: color var(--t-fast);
}
.prod-info__item summary::-webkit-details-marker { display: none; }
.prod-info__item summary:hover { color: var(--c-accent-dk); }
.prod-info__icon { font-size: 16px; line-height: 1; }
.prod-info__title {
  flex: 1;
  font-weight: var(--fw-medium);
  letter-spacing: 0;
  font-size: var(--fs-sm);
}
.prod-info__chev {
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-muted);
  transition: transform var(--t), color var(--t-fast);
}
.prod-info__item[open] .prod-info__chev { transform: rotate(180deg); color: var(--c-ink); }

.prod-info__body {
  padding: 0 0 var(--sp-5);
  font-size: var(--fs-sm);
  color: var(--c-ink-soft);
  animation: prod-info-slide 240ms cubic-bezier(.4,0,.2,1);
}
@keyframes prod-info-slide {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.prod-info__lead {
  margin: 0 0 var(--sp-3);
  font-size: var(--fs-xs);
  color: var(--c-muted);
  line-height: 1.6;
}
.prod-info__hint {
  margin: var(--sp-3) 0 0;
  font-size: var(--fs-xs);
  color: var(--c-muted);
  line-height: 1.5;
}

.size-table {
  width: 100%;
  border-collapse: collapse;
  font-variant-numeric: tabular-nums;
  margin: 0;
  font-size: var(--fs-sm);
  background: var(--c-bg-cream);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.size-table th,
.size-table td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid #E5E3DE;
}
.size-table thead th {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-extra);
  font-weight: var(--fw-semibold);
  color: var(--c-muted);
  background: #EFEDE8;
}
.size-table tbody tr:last-child td { border-bottom: 0; }
.size-table tbody tr:hover td { background: rgba(255,255,255,0.5); }
.size-table td:first-child { width: 90px; }
.size-table strong { color: var(--c-ink); font-size: var(--fs-base); font-weight: var(--fw-semibold); }

.prod-info__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.prod-info__list li {
  padding: 10px 14px;
  background: var(--c-bg-cream);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.prod-info__list strong { color: var(--c-ink); }

.prod-info__care {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
.prod-info__care li {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: 8px 12px;
  background: var(--c-bg-cream);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
}
.prod-info__icon-sm {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  font-size: 14px;
  flex-shrink: 0;
}
@media (max-width: 480px) {
  .size-table th, .size-table td { padding: 8px 10px; font-size: 12px; }
}

/* Mobile: keep CTA inline (don't fix it to viewport — it covers the image) */
@media (max-width: 720px) {
  .single_add_to_cart_button.btn {
    padding: 16px 20px;
    font-size: var(--fs-sm);
  }
  .bundle-perks { font-size: var(--fs-xs); }
}

/* Tabs */
.woocommerce-tabs {
  margin-top: var(--sp-16); padding-top: var(--sp-10); border-top: 1px solid var(--c-line);
}
.woocommerce-tabs .tabs {
  display: flex; gap: var(--sp-6); list-style: none; padding: 0; margin: 0 0 var(--sp-6); border-bottom: 1px solid var(--c-line);
}
.woocommerce-tabs .tabs li a {
  display: inline-block; padding: 12px 0; font-size: var(--fs-sm); font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--c-muted);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.woocommerce-tabs .tabs li.active a { color: var(--c-ink); border-bottom-color: var(--c-ink); }

/* Related products */
.related.products,
.up-sells.products {
  margin-top: var(--sp-20); padding-top: var(--sp-12); border-top: 1px solid var(--c-line);
}
.related.products > h2,
.up-sells.products > h2 {
  font-size: clamp(24px, 3vw, 32px); margin-bottom: var(--sp-8); font-weight: 400; text-align: center;
}

/* Breadcrumbs */
.woocommerce-breadcrumb {
  font-size: var(--fs-xs);
  color: var(--c-muted);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  margin-bottom: var(--sp-6);
}
.woocommerce-breadcrumb a { color: var(--c-muted); }
.woocommerce-breadcrumb a:hover { color: var(--c-ink); }
