/* ── PRODUCT DETAIL PAGE ── */

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}

/* ── OVERFLOW CONTAINMENT ── */
.pdp-breadcrumb,
.pdp-layout,
.pdp-gallery,
.pdp-info,
.pdp-below,
.pdp-sticky-cta {
  max-width: 100%;
  box-sizing: border-box;
}

/* ── BREADCRUMB ── */
.pdp-breadcrumb {
  max-width: 100%;
  padding: 16px 16px 0;
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--mid-grey);
}
.pdp-breadcrumb a { color: var(--mid-grey); text-decoration: none; transition: color 0.2s; }
.pdp-breadcrumb a:hover { color: var(--black); }
.pdp-breadcrumb i { font-size: 9px; }
.pdp-breadcrumb span { color: var(--black); font-weight: 500; }

/* ── MAIN LAYOUT ── */
.pdp-layout {
  max-width: 100%;
  padding: 20px 32px 80px;
  display: grid;
  grid-template-columns: 50% 1fr;
  gap: 48px;
  align-items: start;
}

/* ── IMAGE GALLERY ── */
.pdp-gallery {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 12px;
  position: sticky;
  top: 80px;
}

.pdp-thumbs {
  display: flex; flex-direction: column; gap: 8px;
}
.pdp-thumb {
  width: 80px; height: 100px;
  border: 2px solid transparent;
  cursor: pointer; overflow: hidden;
  transition: border-color 0.2s;
  flex-shrink: 0;
}
.pdp-thumb.active { border-color: var(--black); }
.pdp-thumb img {
  width: 100%; height: 100%; object-fit: cover; object-position: top;
  display: block;
}

.pdp-main-img-wrap {
  position: relative; aspect-ratio: 1/1; overflow: hidden;
  background: #f4f4f4;
}
.pdp-main-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
  transition: opacity 0.3s, transform 0.1s ease;
  transform-origin: center center;
  will-change: transform;
}
.pdp-main-img-wrap.zoomed { cursor: crosshair; }
.pdp-main-img-wrap.zoomed .pdp-main-img { transform: scale(2.2); }
.pdp-img-badge {
  position: absolute; top: 14px; left: 14px;
  background: var(--accent); color: var(--black);
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; padding: 5px 10px;
}
.pdp-img-discount {
  position: absolute; top: 14px; right: 14px;
  background: #e63946; color: #fff;
  font-size: 11px; font-weight: 700; padding: 5px 9px;
}
.pdp-img-wish {
  position: absolute; bottom: 16px; right: 16px;
  width: 40px; height: 40px;
  background: #fff; border-radius: 50%; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; color: var(--black);
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  transition: transform 0.2s, color 0.2s;
}
.pdp-img-wish:hover { transform: scale(1.1); }
.pdp-img-wish.wishlisted { color: #e63946; }

/* Mobile image slider dots */
.pdp-img-dots {
  position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%);
  display: none; gap: 5px;
}
.pdp-img-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,0.5); border: none; cursor: pointer; padding: 0;
  transition: background 0.2s;
}
.pdp-img-dot.active { background: #fff; }

/* ── PRODUCT INFO PANEL ── */
.pdp-info {
  display: flex; flex-direction: column; gap: 0;
}

.pdp-brand-tag {
  font-size: 11px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--mid-grey); margin-bottom: 6px;
}
.pdp-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.5vw, 42px);
  line-height: 1.05; color: var(--black); margin-bottom: 12px;
  letter-spacing: 1px;
}

.pdp-rating-row {
  display: flex; align-items: center; gap: 10px; margin-bottom: 16px;
}
.pdp-stars { color: #f5a623; font-size: 14px; letter-spacing: 1px; }
.pdp-rating-count { font-size: 13px; color: var(--mid-grey); text-decoration: underline; cursor: pointer; }
.pdp-rating-count:hover { color: var(--black); }

.pdp-price-row {
  display: flex; align-items: baseline; gap: 10px; margin-bottom: 6px;
}
.pdp-price {
  font-size: 28px; font-weight: 700; color: var(--black);
}
.pdp-original {
  font-size: 16px; color: var(--mid-grey); text-decoration: line-through;
}
.pdp-off {
  font-size: 14px; font-weight: 700; color: #e63946;
}
.pdp-tax-note {
  font-size: 11px; color: var(--mid-grey); margin-bottom: 20px;
}

.pdp-divider { height: 1px; background: #e5e5e5; margin: 20px 0; }

/* ── COLOR SELECTOR ── */
.pdp-section-label {
  font-size: 12px; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--black); margin-bottom: 10px;
}
.pdp-section-label span { color: var(--mid-grey); font-weight: 400; letter-spacing: 0; text-transform: none; }

.pdp-colors {
  display: flex; gap: 8px; margin-bottom: 20px;
}
.pdp-color {
  width: 32px; height: 32px; border-radius: 50%;
  border: 2px solid transparent; cursor: pointer;
  position: relative; transition: border-color 0.2s;
  outline: 2px solid transparent; outline-offset: 2px;
}
.pdp-color.active { outline-color: var(--black); }
.pdp-color[title="Black"] { background: #111; }
.pdp-color[title="Slate Grey"] { background: #708090; }
.pdp-color[title="Olive"] { background: #6b7c45; }
.pdp-color[title="Cream"] { background: #f5f0e8; border: 2px solid #ddd; }

/* ── SIZE CHART DRAWER ── */
.size-chart-overlay {
  position: fixed; inset: 0; z-index: 1500;
  background: rgba(10,10,10,0.55);
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
  backdrop-filter: blur(2px);
}
.size-chart-overlay.open { opacity: 1; pointer-events: all; }

.size-chart-drawer {
  position: fixed; top: 0; left: 0; bottom: 0; z-index: 1501;
  width: 480px; max-width: 95vw;
  background: var(--white);
  transform: translateX(-100%);
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.size-chart-drawer.open { transform: translateX(0); }

.size-chart-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid #f0f0f0;
  flex-shrink: 0;
}
.size-chart-head h3 {
  font-family: var(--font-display);
  font-size: 24px; letter-spacing: 1px; color: var(--black);
}
.size-chart-close {
  width: 36px; height: 36px; background: none; border: none;
  cursor: pointer; font-size: 18px; color: var(--black);
  display: flex; align-items: center; justify-content: center;
  transition: opacity 0.2s;
}
.size-chart-close:hover { opacity: 0.5; }

.size-chart-body {
  flex: 1; overflow-y: auto; padding: 24px;
}

.size-chart-note {
  font-size: 12px; color: var(--mid-grey); margin-bottom: 20px;
  padding: 10px 14px; background: #f8f8f8; border-left: 3px solid var(--accent);
}

.size-chart-img {
  width: 100%; border: 1px solid #f0f0f0; margin-bottom: 20px;
  display: block;
}

.size-chart-table-wrap { overflow-x: auto; margin-bottom: 24px; }
.size-chart-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.size-chart-table th {
  background: var(--black); color: var(--white);
  padding: 10px 14px; text-align: center;
  font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
}
.size-chart-table td {
  padding: 10px 14px; text-align: center;
  border-bottom: 1px solid #f0f0f0; color: #333;
}
.size-chart-table tr:nth-child(even) td { background: #fafafa; }
.size-chart-table tr:hover td { background: #f5f5f5; }
.size-chart-table td:first-child {
  font-weight: 700; color: var(--black);
}

.size-chart-unit-toggle {
  display: flex; gap: 0; margin-bottom: 16px; border: 1.5px solid var(--black);
  width: fit-content;
}
.size-chart-unit-btn {
  padding: 7px 20px; font-size: 12px; font-weight: 600; cursor: pointer;
  background: none; border: none; transition: all 0.18s;
  color: var(--black);
}
.size-chart-unit-btn.active { background: var(--black); color: var(--white); }

@media (max-width: 480px) {
  .size-chart-drawer { width: 100vw; }
}

/* ── SIZE SELECTOR ── */
.pdp-sizes {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 8px;
}
.pdp-size-btn {
  min-width: 52px; height: 48px; padding: 0 12px;
  border: 1.5px solid #ddd; background: none;
  font-size: 13px; font-weight: 600; cursor: pointer;
  transition: all 0.18s; color: var(--black);
  display: flex; align-items: center; justify-content: center;
}
.pdp-size-btn:hover { border-color: var(--black); }
.pdp-size-btn.active { background: var(--black); color: var(--white); border-color: var(--black); }
.pdp-size-btn.sold-out {
  color: #ccc; border-color: #eee; cursor: not-allowed;
  text-decoration: line-through; pointer-events: none;
}

.pdp-size-guide {
  font-size: 12px; color: var(--mid-grey); text-decoration: underline;
  cursor: pointer; margin-bottom: 24px; display: inline-flex;
  align-items: center; gap: 5px;
  background: none; border: none; padding: 0; font-family: var(--font-body);
}
.pdp-size-guide:hover { color: var(--black); }

/* ── CTA BUTTONS ── */
.pdp-cta {
  display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px;
}
.pdp-btn-cart {
  width: 100%; height: 54px;
  background: var(--black); color: var(--white);
  border: 2px solid var(--black); font-size: 14px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer;
  transition: background 0.22s, color 0.22s;
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.pdp-btn-cart:hover { background: var(--accent); color: var(--black); border-color: var(--accent); }
.pdp-btn-buy {
  width: 100%; height: 54px;
  background: var(--accent); color: var(--black);
  border: 2px solid var(--accent); font-size: 14px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer;
  transition: background 0.22s;
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.pdp-btn-buy:hover { background: var(--accent); }

/* ── WRITE REVIEW BTN ── */
.pdp-write-review-btn {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 12px 16px;
  background: none; border: 1.5px solid #e0e0e0;
  font-size: 13px; font-weight: 600; color: var(--black);
  cursor: pointer; letter-spacing: 0.5px;
  margin-bottom: 16px;
  transition: border-color 0.2s, background 0.2s;
}
.pdp-write-review-btn:hover { border-color: var(--black); background: #f8f8f8; }

/* ── SOLD URGENCY ── */
.pdp-sold-urgency {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: #333;
  background: #fff8f0; border-left: 3px solid #f4a340;
  padding: 10px 14px; margin-bottom: 14px;
}
.pdp-sold-urgency i { color: #f4a340; font-size: 14px; }

/* ── REVIEW MODAL ── */
.review-modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,0.5);
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
}
.review-modal-overlay.open { opacity: 1; pointer-events: all; }
.review-modal {
  position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -48%);
  z-index: 2001; width: 480px; max-width: 95vw;
  background: #fff;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
}
.review-modal.open { opacity: 1; pointer-events: all; transform: translate(-50%, -50%); }
.review-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px; border-bottom: 1px solid #f0f0f0;
}
.review-modal-head h3 { font-family: var(--font-display); font-size: 22px; letter-spacing: 1px; }
.review-modal-close {
  background: none; border: none; font-size: 18px; cursor: pointer; color: var(--black);
}
.review-modal-body { padding: 24px; display: flex; flex-direction: column; gap: 16px; }
.review-star-label { font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 6px; }
.review-stars-input { display: flex; gap: 4px; }
.rstar { font-size: 28px; color: #ddd; cursor: pointer; transition: color 0.15s; }
.rstar.active { color: #f5a623; }
.review-form-group { display: flex; flex-direction: column; gap: 6px; }
.review-form-group label { font-size: 12px; font-weight: 600; letter-spacing: 0.5px; }
.review-form-group input,
.review-form-group textarea {
  border: 1.5px solid #e0e0e0; padding: 10px 12px;
  font-size: 14px; font-family: var(--font-body);
  outline: none; resize: none;
  transition: border-color 0.2s;
}
.review-form-group input:focus,
.review-form-group textarea:focus { border-color: var(--black); }
.review-submit-btn {
  background: var(--black); color: #fff;
  border: none; padding: 14px; font-size: 14px;
  font-weight: 700; letter-spacing: 1px; cursor: pointer;
  text-transform: uppercase; transition: opacity 0.2s;
}
.review-submit-btn:hover { opacity: 0.8; }

/* ── REVIEW IMAGE UPLOAD ── */
.review-img-hint { font-weight: 400; color: var(--mid-grey); text-transform: none; letter-spacing: 0; }
.review-img-upload-row { display: flex; gap: 10px; }
.review-img-slot {
  width: 80px; height: 80px;
  border: 1.5px dashed #d0d0d0;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; position: relative; overflow: hidden;
  background: #fafafa; transition: border-color 0.2s;
  flex-shrink: 0;
}
.review-img-slot:hover { border-color: var(--black); }
.review-img-slot.filled { border-style: solid; border-color: #d0d0d0; }
.review-img-plus { font-size: 18px; color: #bbb; pointer-events: none; }
.review-img-preview {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; border-radius: 6px;
}
.review-img-remove {
  position: absolute; top: 3px; right: 3px;
  width: 18px; height: 18px;
  background: rgba(0,0,0,0.6); color: #fff;
  border: none; border-radius: 50%; font-size: 9px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 2; padding: 0;
}
.review-img-remove:hover { background: rgba(0,0,0,0.85); }

/* ── REVIEW DISPLAY IMAGES ── */
.pdp-review-imgs { display: flex; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.pdp-review-thumb {
  width: 72px; height: 72px; object-fit: cover;
  border-radius: 6px; cursor: pointer; border: 1px solid #eee;
  transition: transform 0.2s, box-shadow 0.2s;
}
.pdp-review-thumb:hover { transform: scale(1.05); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }

/* ── REVIEW LIGHTBOX ── */
.review-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.88); backdrop-filter: blur(6px);
  display: none; align-items: center; justify-content: center;
}
.review-lightbox.open { display: flex; }
.review-lightbox-img {
  max-width: 90vw; max-height: 88vh;
  object-fit: contain; border-radius: 4px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.review-lightbox-close {
  position: absolute; top: 20px; right: 24px;
  background: rgba(255,255,255,0.12); border: none;
  color: #fff; font-size: 18px; width: 40px; height: 40px;
  border-radius: 50%; cursor: pointer; display: flex;
  align-items: center; justify-content: center;
  transition: background 0.2s;
}
.review-lightbox-close:hover { background: rgba(255,255,255,0.22); }

/* ── MODEL NOTE ── */
.pdp-model-note {
  font-size: 12px;
  color: #767676;
  margin: 8px 0 0;
  display: flex;
  align-items: center;
  gap: 6px;
  letter-spacing: 0.01em;
}

/* ── TRUST CHIPS ── */
.pdp-urgency {
  display: flex; align-items: center; gap: 8px;
  background: #fff8f0; border: 1px solid #f5d9b0;
  border-radius: 6px; padding: 10px 14px; margin-bottom: 14px;
  font-size: 13px; color: #b45309;
}
.pdp-urgency i { font-size: 14px; flex-shrink: 0; }
.pdp-urgency strong { color: #92400e; }

.pdp-scarcity {
  display: flex; align-items: center; gap: 8px;
  background: #fff5f5; border: 1px solid #fecaca;
  border-radius: 6px; padding: 10px 14px; margin-bottom: 14px;
  font-size: 13px; color: #dc2626;
}
.pdp-scarcity--mild {
  background: #fffbeb; border-color: #fde68a; color: #b45309;
}
.pdp-scarcity i { font-size: 14px; flex-shrink: 0; }
.pdp-scarcity strong { font-weight: 700; }

.pdp-trust {
  display: flex; gap: 0; margin-bottom: 24px;
  border: 1px solid #f0f0f0;
}
.pdp-trust-item {
  flex: 1; padding: 12px 8px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  border-right: 1px solid #f0f0f0; font-size: 11px; color: var(--mid-grey);
  text-align: center;
}
.pdp-trust-item:last-child { border-right: none; }
.pdp-trust-item i { font-size: 16px; color: var(--black); }
.pdp-trust-item strong { font-size: 11px; color: var(--black); font-weight: 600; }

/* ── ACCORDION DETAILS ── */
.pdp-accordion { border-top: 1px solid #f0f0f0; }
.pdp-acc-item { border-bottom: 1px solid #f0f0f0; }
.pdp-acc-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 0; cursor: pointer;
  font-size: 13px; font-weight: 600; letter-spacing: 0.5px;
  text-transform: uppercase; color: var(--black);
  background: none; border: none; width: 100%; text-align: left;
}
.pdp-acc-head i { font-size: 12px; transition: transform 0.3s; color: var(--mid-grey); }
.pdp-acc-item.open .pdp-acc-head i { transform: rotate(45deg); }
.pdp-acc-body {
  max-height: 0; overflow: hidden;
  transition: max-height 0.35s cubic-bezier(0.4,0,0.2,1);
}
.pdp-acc-item.open .pdp-acc-body { max-height: 400px; }
.pdp-acc-content {
  padding: 0 0 20px;
  font-size: 13px; line-height: 1.7; color: #555;
}
.pdp-acc-content ul { padding-left: 18px; }
.pdp-acc-content li { margin-bottom: 4px; }

/* ── BELOW FOLD ── */
.pdp-below {
  max-width: 100%; padding: 0 16px 80px;
}

/* Reviews */
.pdp-reviews-title-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 24px;
}
.pdp-section-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  letter-spacing: 1px; margin-bottom: 0;
}
.pdp-write-review-btn-inline {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 20px;
  background: none; border: 1.5px solid var(--black);
  font-size: 13px; font-weight: 600; color: var(--black);
  cursor: pointer; letter-spacing: 0.5px;
  transition: background 0.2s, color 0.2s;
}
.pdp-write-review-btn-inline:hover { background: var(--black); color: #fff; }
.pdp-reviews-summary {
  display: flex; gap: 40px; align-items: center; margin-bottom: 32px;
  padding-bottom: 32px; border-bottom: 1px solid #f0f0f0;
}
.pdp-avg-score {
  text-align: center; flex-shrink: 0;
}
.pdp-avg-num {
  font-family: var(--font-display); font-size: 64px; line-height: 1;
}
.pdp-avg-stars { color: #f5a623; font-size: 18px; letter-spacing: 2px; margin-bottom: 4px; }
.pdp-avg-label { font-size: 12px; color: var(--mid-grey); }
.pdp-rating-bars { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.pdp-bar-row { display: flex; align-items: center; gap: 10px; font-size: 12px; }
.pdp-bar-wrap { flex: 1; height: 6px; background: #f0f0f0; border-radius: 3px; overflow: hidden; }
.pdp-bar-fill { height: 100%; background: var(--black); border-radius: 3px; }

.pdp-review-grid {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 32px;
  padding-bottom: 4px;
}
.pdp-review-grid::-webkit-scrollbar { display: none; }
.pdp-review-card {
  padding: 20px; border: 1px solid #f0f0f0;
  min-width: 300px; max-width: 300px;
  flex-shrink: 0;
  scroll-snap-align: start;
}
.pdp-review-stars { color: #f5a623; font-size: 13px; margin-bottom: 8px; }
.pdp-review-text { font-size: 13px; line-height: 1.6; color: #444; margin-bottom: 6px; }
.pdp-review-author { font-size: 12px; font-weight: 600; }
.pdp-review-date { font-size: 11px; color: var(--mid-grey); }
.pdp-review-verified {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; color: #2e7d32; font-weight: 600;
  margin-top: 4px;
}

/* ── READ MORE BUTTON ── */
.review-read-more {
  display: inline-block; font-size: 12px; font-weight: 600;
  color: var(--black); text-decoration: underline; text-underline-offset: 2px;
  background: none; border: none; cursor: pointer; padding: 0;
  margin-bottom: 12px; letter-spacing: 0.3px;
  transition: color 0.2s;
}
.review-read-more:hover { color: var(--accent); }

/* ── VIEW ALL REVIEWS ── */
.pdp-reviews-view-all-row {
  display: flex; justify-content: center; margin-top: 28px;
}
.pdp-view-all-reviews-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 32px; border: 2px solid var(--black);
  background: none; color: var(--black);
  font-size: 13px; font-weight: 700; letter-spacing: 1px;
  text-transform: uppercase; cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.pdp-view-all-reviews-btn:hover { background: var(--black); color: #fff; }

/* ── SINGLE REVIEW DETAIL MODAL ── */
.review-detail-overlay {
  position: fixed; inset: 0; z-index: 3000;
  background: rgba(0,0,0,0.55); backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none; transition: opacity 0.3s;
}
.review-detail-overlay.open { opacity: 1; pointer-events: all; }
.review-detail-modal {
  position: fixed; top: 50%; left: 50%; z-index: 3001;
  transform: translate(-50%, -48%);
  width: min(560px, 92vw); max-height: 80vh;
  background: #fff; display: flex; flex-direction: column;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  border-radius: 4px; overflow: hidden;
}
.review-detail-modal.open { opacity: 1; pointer-events: all; transform: translate(-50%, -50%); }
.review-detail-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid #f0f0f0;
}
.review-detail-stars { color: #f5a623; font-size: 16px; }
.review-detail-close {
  background: none; border: none; cursor: pointer;
  font-size: 18px; color: var(--mid-grey);
  display: flex; align-items: center; justify-content: center;
  transition: color 0.2s;
}
.review-detail-close:hover { color: var(--black); }
.review-detail-body { padding: 20px; overflow-y: auto; display: flex; flex-direction: column; gap: 16px; }
.review-detail-text { font-size: 14px; line-height: 1.75; color: #333; }
.review-detail-imgs { display: flex; gap: 10px; flex-wrap: wrap; }
.review-detail-thumb {
  width: 90px; height: 90px; object-fit: cover;
  border-radius: 6px; cursor: pointer; border: 1px solid #eee;
  transition: transform 0.2s;
}
.review-detail-thumb:hover { transform: scale(1.05); }
.review-detail-meta {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding-top: 12px; border-top: 1px solid #f0f0f0;
}
.review-detail-author { font-size: 13px; font-weight: 700; color: var(--black); }
.review-detail-date { font-size: 12px; color: var(--mid-grey); }
.review-detail-verified {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; color: #2e7d32; font-weight: 600;
}

/* ── ALL REVIEWS MODAL ── */
.all-reviews-overlay {
  position: fixed; inset: 0; z-index: 3000;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none; transition: opacity 0.3s;
}
.all-reviews-overlay.open { opacity: 1; pointer-events: all; }
.all-reviews-modal {
  position: fixed; top: 50%; left: 50%; z-index: 3001;
  transform: translate(-50%, -48%);
  width: min(960px, 96vw); height: 85vh;
  background: #fff; display: flex; flex-direction: column;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  border-radius: 4px; overflow: hidden;
}
.all-reviews-modal.open { opacity: 1; pointer-events: all; transform: translate(-50%, -50%); }
.all-reviews-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px; border-bottom: 1px solid #f0f0f0; flex-shrink: 0;
}
.all-reviews-head h3 { font-family: var(--font-display); font-size: 22px; letter-spacing: 1px; }
.all-reviews-head span { color: var(--mid-grey); font-size: 16px; }
.all-reviews-close {
  background: none; border: none; cursor: pointer;
  font-size: 20px; color: var(--mid-grey); transition: color 0.2s;
  display: flex; align-items: center;
}
.all-reviews-close:hover { color: var(--black); }
.all-reviews-body {
  flex: 1; overflow-y: auto; padding: 24px;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px; align-content: start;
}
.all-reviews-card {
  min-width: unset !important; max-width: unset !important;
  scroll-snap-align: unset !important;
}

/* Related products */
.pdp-related { margin-top: 60px; }
.pdp-related-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px;
}

/* Recently Viewed */
.pdp-recently-viewed { margin-top: 60px; }
.rv-card {
  display: block; text-decoration: none; color: inherit;
}
.rv-img-wrap {
  width: 100%; aspect-ratio: 3/4; overflow: hidden; background: var(--grey);
}
.rv-img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .4s ease;
}
.rv-card:hover .rv-img-wrap img { transform: scale(1.04); }
.rv-info { padding: 10px 4px 14px; }
.rv-name {
  font-size: 13px; font-weight: 500; color: var(--black);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 4px;
}
.rv-price { font-size: 13px; color: var(--mid-grey); }

/* ── CART DRAWER ── */
.cart-drawer-overlay {
  position: fixed; inset: 0; z-index: 1800;
  background: rgba(10,10,10,0.5);
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
  backdrop-filter: blur(2px);
}
.cart-drawer-overlay.open { opacity: 1; pointer-events: all; }

.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 1801;
  width: 420px; max-width: 100vw;
  background: var(--white);
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
  display: flex; flex-direction: column;
}
.cart-drawer.open { transform: translateX(0); }

.cart-drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; border-bottom: 1px solid #f0f0f0; flex-shrink: 0;
}
.cart-drawer-title {
  font-family: var(--font-display); font-size: 22px; letter-spacing: 1px;
  display: flex; align-items: center; gap: 10px;
}
.cart-drawer-count {
  font-family: var(--font-body); font-size: 12px; font-weight: 700;
  background: var(--black); color: var(--white);
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.cart-drawer-close {
  width: 36px; height: 36px; background: none; border: none;
  cursor: pointer; font-size: 18px; color: var(--black);
  display: flex; align-items: center; justify-content: center;
  transition: opacity 0.2s;
}
.cart-drawer-close:hover { opacity: 0.5; }

/* Free shipping progress */
.cart-shipping-bar {
  padding: 14px 24px; background: #f8f8f8; border-bottom: 1px solid #f0f0f0;
  flex-shrink: 0;
}
.cart-shipping-text {
  font-size: 12px; color: #444; margin-bottom: 8px;
}
.cart-shipping-text strong { color: var(--black); }
.cart-shipping-track {
  height: 4px; background: #e0e0e0; border-radius: 2px; overflow: hidden;
}
.cart-shipping-fill {
  height: 100%; background: var(--accent); border-radius: 2px;
  transition: width 0.5s cubic-bezier(0.4,0,0.2,1);
}

/* Items list */
.cart-drawer-items {
  flex: 1; overflow-y: auto; padding: 16px 24px;
}

.cart-item {
  display: flex; gap: 14px; padding: 16px 0;
  border-bottom: 1px solid #f5f5f5;
  animation: cartItemIn 0.35s cubic-bezier(0.4,0,0.2,1);
}
@keyframes cartItemIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.cart-item-img {
  width: 80px; height: 100px; object-fit: cover;
  object-position: top; flex-shrink: 0; background: #ececec;
}
.cart-item-info { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.cart-item-brand { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; color: var(--mid-grey); text-transform: uppercase; }
.cart-item-name { font-size: 14px; font-weight: 600; color: var(--black); line-height: 1.3; }
.cart-item-meta { font-size: 12px; color: var(--mid-grey); }
.cart-item-price-row { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 8px; }
.cart-item-price { font-size: 15px; font-weight: 700; color: var(--black); }
.cart-item-original { font-size: 12px; color: var(--mid-grey); text-decoration: line-through; }

.cart-qty {
  display: flex; align-items: center; gap: 0;
  border: 1.5px solid #e0e0e0;
}
.cart-qty-btn {
  width: 30px; height: 30px; background: none; border: none;
  cursor: pointer; font-size: 16px; color: var(--black);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.cart-qty-btn:hover { background: #f5f5f5; }
.cart-qty-num { width: 32px; text-align: center; font-size: 13px; font-weight: 600; }

.cart-item-remove {
  background: none; border: none; cursor: pointer;
  font-size: 12px; color: var(--mid-grey); padding: 0;
  text-decoration: underline; transition: color 0.2s;
  align-self: flex-start;
}
.cart-item-remove:hover { color: #e63946; }

/* Empty state */
.cart-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px;
  padding: 40px 24px; text-align: center;
}
.cart-empty i { font-size: 48px; color: #e0e0e0; }
.cart-empty h4 { font-family: var(--font-display); font-size: 22px; letter-spacing: 1px; }
.cart-empty p { font-size: 13px; color: var(--mid-grey); }
.cart-empty-shop {
  margin-top: 8px; padding: 12px 28px;
  background: var(--black); color: var(--white);
  font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  border: none; cursor: pointer; text-decoration: none;
  display: inline-block;
}

/* Footer */
.cart-drawer-footer {
  padding: 20px 24px; border-top: 1px solid #f0f0f0; flex-shrink: 0;
}
.cart-subtotal-row {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 6px;
}
.cart-subtotal-label { font-size: 13px; color: var(--mid-grey); }
.cart-subtotal-val { font-size: 20px; font-weight: 700; color: var(--black); }
.cart-savings {
  font-size: 12px; color: #2e7d32; font-weight: 600; margin-bottom: 16px;
}
.cart-btn-checkout {
  width: 100%; height: 52px;
  background: var(--black); color: var(--white);
  border: none; font-size: 14px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer;
  transition: background 0.2s;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin-bottom: 10px; text-decoration: none;
}
.cart-btn-checkout:hover { background: #222; }
.cart-btn-continue {
  width: 100%; height: 44px;
  background: none; color: var(--black);
  border: 1.5px solid #e0e0e0; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: border-color 0.2s;
  letter-spacing: 0.5px;
}
.cart-btn-continue:hover { border-color: var(--black); }

/* Button added state */
.pdp-btn-cart.added {
  background: #2e7d32; border-color: #2e7d32;
}

/* ── RELATED CARD QUICK ADD ── */
.pcard-quick-add {
  width: 100%; height: 38px; margin-top: 10px;
  background: var(--black); color: var(--white);
  border: none; font-size: 11px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  opacity: 0; transform: translateY(4px);
  transition: opacity 0.2s, transform 0.2s, background 0.2s;
}
.pcard:hover .pcard-quick-add { opacity: 1; transform: translateY(0); }
.pcard-quick-add:hover { background: #333; }
.pcard-quick-add.added { background: #2e7d32; }

/* ── STICKY MOBILE CTA ── */
.pdp-sticky-cta {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
  background: #fff; border-top: 1px solid #f0f0f0;
  padding: 12px 16px;
  gap: 10px;
}
.pdp-sticky-cta .pdp-btn-cart,
.pdp-sticky-cta .pdp-btn-buy {
  flex: 1; height: 48px; font-size: 13px;
}

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .pdp-layout { grid-template-columns: 1fr 400px; gap: 32px; }
  .pdp-related-grid { grid-template-columns: repeat(3, 1fr); }
  .pdp-review-grid { /* carousel — no grid override needed */ }
}

@media (max-width: 768px) {
  .pdp-layout {
    grid-template-columns: 1fr;
    padding: 12px 0 100px;
    gap: 0;
  }
  .pdp-breadcrumb { padding: 12px 16px 0; }
  .pdp-gallery {
    grid-template-columns: 1fr;
    position: static;
    gap: 0;
  }
  .pdp-thumbs { display: none; }
  .pdp-main-img-wrap { aspect-ratio: 1/1; }
  .pdp-img-dots { display: flex; }
  .pdp-info { padding: 20px 16px 0; }
  .pdp-trust { flex-wrap: wrap; }
  .pdp-trust-item { min-width: 50%; border-bottom: 1px solid #f0f0f0; }
  .pdp-cta { flex-direction: row; }
  .pdp-btn-cart, .pdp-btn-buy { height: 48px; font-size: 13px; }
  .pdp-below { padding: 0 16px 120px; }
  .pdp-related-grid { grid-template-columns: repeat(2, 1fr); }
  .pdp-review-card { min-width: 260px; max-width: 260px; }
  .pdp-reviews-summary { flex-direction: column; gap: 20px; align-items: stretch; }
  .pdp-rating-bars { width: 100%; }
  .pdp-bar-row { width: 100%; }
  .pdp-sticky-cta { display: flex; }
  .pdp-cta { display: none; }
}

@media (max-width: 480px) {
  .pdp-gallery { grid-template-columns: 1fr; }
  .pdp-title { font-size: 24px; }

  /* Breadcrumb: wrap and truncate long product name */
  .pdp-breadcrumb { flex-wrap: wrap; gap: 4px; padding: 10px 16px 0; }
  .pdp-breadcrumb span {
    white-space: nowrap; overflow: hidden;
    text-overflow: ellipsis; max-width: 200px;
  }

  /* Rating row: wrap to 2 lines */
  .pdp-rating-row { flex-wrap: wrap; gap: 6px; }

  /* Price row: wrap discount badge */
  .pdp-price-row { flex-wrap: wrap; align-items: center; }

  /* Size label row with size guide button: stack */
  .pdp-section-label { flex-wrap: wrap; gap: 4px; }
  .pdp-size-guide { margin-bottom: 0; }

  /* Trust bar: force 2×2 grid */
  .pdp-trust { flex-wrap: wrap; }
  .pdp-trust-item { min-width: 50%; box-sizing: border-box; }

  /* Below fold */
  .pdp-below { padding: 0 12px 120px; }

  /* Reviews header: stack title + button */
  .pdp-reviews-title-row { flex-direction: column; align-items: flex-start; gap: 12px; }
  .pdp-write-review-btn-inline { width: 100%; justify-content: center; }
  .pdp-section-title { font-size: 24px; }

  /* Related grid: 2 columns on small mobile */
  .pdp-related-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── CART DRAWER ── */
.cart-drawer-overlay {
  position: fixed; inset: 0; z-index: 1800;
  background: rgba(10,10,10,0.5);
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
  backdrop-filter: blur(2px);
}
.cart-drawer-overlay.open { opacity: 1; pointer-events: all; }

.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 1801;
  width: 420px; max-width: 100vw;
  background: #fff;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
  display: flex; flex-direction: column;
}
.cart-drawer.open { transform: translateX(0); }

.cart-drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; border-bottom: 1px solid #f0f0f0; flex-shrink: 0;
}
.cart-drawer-title {
  font-family: 'Barlow Condensed', sans-serif; font-size: 22px; letter-spacing: 1px;
  display: flex; align-items: center; gap: 10px; text-transform: uppercase;
}
.cart-drawer-count {
  font-family: inherit; font-size: 12px; font-weight: 700;
  background: #111; color: #fff;
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.cart-drawer-close {
  width: 36px; height: 36px; background: none; border: none;
  cursor: pointer; font-size: 18px; color: #111;
  display: flex; align-items: center; justify-content: center;
  transition: opacity 0.2s;
}
.cart-drawer-close:hover { opacity: 0.5; }

.cart-shipping-bar {
  padding: 14px 24px; background: #f8f8f8; border-bottom: 1px solid #f0f0f0; flex-shrink: 0;
}
.cart-shipping-text { font-size: 12px; color: #444; margin-bottom: 8px; }
.cart-shipping-text strong { color: #111; }
.cart-shipping-track { height: 4px; background: #e0e0e0; border-radius: 2px; overflow: hidden; }
.cart-shipping-fill { height: 100%; background: #c8a96e; border-radius: 2px; transition: width 0.5s cubic-bezier(0.4,0,0.2,1); }

.cart-drawer-items { flex: 1; overflow-y: auto; padding: 16px 24px; }

.cart-drawer .cart-item {
  display: flex; gap: 14px; padding: 16px 0;
  border-bottom: 1px solid #f5f5f5;
}
.cart-drawer .cart-item-img {
  width: 80px; height: 100px; object-fit: cover;
  object-position: top; flex-shrink: 0; background: #ececec;
}
.cart-drawer .cart-item-info { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.cart-drawer .cart-item-brand { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; color: #888; text-transform: uppercase; }
.cart-drawer .cart-item-name { font-size: 14px; font-weight: 600; color: #111; line-height: 1.3; }
.cart-drawer .cart-item-meta { font-size: 12px; color: #888; }
.cart-drawer .cart-item-price-row { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 8px; }
.cart-drawer .cart-item-price { font-size: 15px; font-weight: 700; color: #111; }
.cart-drawer .cart-item-original { font-size: 12px; color: #aaa; text-decoration: line-through; margin-left: 6px; }
.cart-drawer .cart-qty { display: flex; align-items: center; border: 1.5px solid #e0e0e0; }
.cart-drawer .cart-qty-btn { width: 30px; height: 30px; background: none; border: none; cursor: pointer; font-size: 16px; color: #111; display: flex; align-items: center; justify-content: center; transition: background 0.15s; }
.cart-drawer .cart-qty-btn:hover { background: #f5f5f5; }
.cart-drawer .cart-qty-num { width: 32px; text-align: center; font-size: 13px; font-weight: 600; }
.cart-drawer .cart-item-remove { background: none; border: none; cursor: pointer; font-size: 12px; color: #aaa; padding: 0; text-decoration: underline; transition: color 0.2s; align-self: flex-start; }
.cart-drawer .cart-item-remove:hover { color: #e63946; }

.cart-drawer-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 40px 24px; text-align: center; }
.cart-drawer-empty i { font-size: 48px; color: #e0e0e0; }
.cart-drawer-empty h4 { font-family: 'Barlow Condensed', sans-serif; font-size: 22px; letter-spacing: 1px; }
.cart-drawer-empty p { font-size: 13px; color: #888; }

.cart-drawer-footer { padding: 20px 24px; border-top: 1px solid #f0f0f0; flex-shrink: 0; }
.cart-subtotal-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.cart-subtotal-label { font-size: 13px; color: #888; }
.cart-subtotal-val { font-size: 20px; font-weight: 700; color: #111; }
.cart-savings-text { font-size: 12px; color: #2e7d32; font-weight: 600; margin-bottom: 16px; }
.cart-btn-checkout {
  width: 100%; height: 52px; background: #111; color: #fff;
  border: none; font-size: 14px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; cursor: pointer; transition: background 0.2s;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin-bottom: 10px; text-decoration: none;
}
.cart-btn-checkout:hover { background: #333; }
.cart-btn-continue {
  width: 100%; height: 44px; background: none; color: #111;
  border: 1.5px solid #e0e0e0; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: border-color 0.2s; letter-spacing: 0.5px;
}
.cart-btn-continue:hover { border-color: #111; }

/* Out of Stock badge */
.pdp-oos-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 52px;
  background: #f5f5f5;
  border: 1.5px solid #e0e0e0;
  color: #999;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  border-radius: 0;
}
