/* ===== Product detail ===== */
.pdp { padding: 28px 28px 20px; }
.pdp-crumbs { margin-bottom: 26px; color: var(--ink-soft); }
.pdp-crumbs a:hover { color: var(--maroon); }
.pdp-crumbs .cur { color: var(--maroon); font-weight: 600; }
.pdp-main { display: grid; grid-template-columns: 1fr 1fr; gap: 54px; }

.pdp-gallery { position: sticky; top: 90px; align-self: start; }
.pdp-hero-img { position: relative; aspect-ratio: 1/1; border-radius: 18px; overflow: hidden; background: var(--cream-2); }
.pdp-hero-img .ark-art { height: 100%; }
.pdp-thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 14px; }
.pdp-thumb { aspect-ratio: 1/1; border-radius: 12px; overflow: hidden; border: 2px solid transparent; background: var(--cream-2); padding: 0; }
.pdp-thumb .ark-art { height: 100%; }
.pdp-thumb.active { border-color: var(--maroon); }

.pdp-info { position: relative; }
.pdp-head { display: flex; flex-direction: column; align-items: flex-start; }
.pdp-wish { position: absolute; top: 0; right: 0; width: 44px; height: 44px; }
.pdp-character { font-family: var(--script); font-size: 30px; color: var(--gold); margin: 0; line-height: 1; }
.pdp-title { font-size: 32px; line-height: 1.18; margin: 4px 0 10px; padding-right: 50px; white-space: nowrap; }
.pdp-rating { display: flex; align-items: center; gap: 8px; margin: 0 0 18px; }
.pdp-reviewcount { font-size: 13px; color: var(--ink-soft); }
.pdp-desc { font-size: 15.5px; line-height: 1.75; color: var(--ink-soft); margin: 0 0 22px; }
.pdp-badges { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 26px; }
.pdp-badge { display: inline-flex; align-items: center; gap: 7px; background: var(--cream-2);
  border: 1px solid var(--card-line); border-radius: 999px; padding: 8px 14px; font-size: 12px; font-weight: 700; color: var(--cocoa); }
.pdp-badge svg { color: var(--gold); }

.pdp-opt { margin-bottom: 24px; }
.pdp-opt-label { display: block; font-size: 12px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 10px; }
.pdp-sizes { display: flex; gap: 10px; }
.pdp-size { background: var(--card); border: 1.5px solid var(--card-line); border-radius: 8px; padding: 11px 22px;
  font-family: var(--sans); font-weight: 700; font-size: 13.5px; color: var(--ink); transition: .15s; display: inline-flex; gap: 7px; align-items: baseline; }
.pdp-size em { font-style: normal; font-size: 11.5px; color: var(--ink-soft); font-weight: 600; }
.pdp-size:hover { border-color: var(--gold); }
.pdp-size.active { border-color: var(--maroon); background: #f7eee6; color: var(--maroon); }
.pdp-size.active em { color: var(--maroon); }

.pdp-buy { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.pdp-stepper { display: inline-flex; align-items: center; border: 1.5px solid var(--card-line); border-radius: 8px; overflow: hidden; }
.pdp-stepper button { background: var(--card); border: none; padding: 12px 14px; color: var(--ink); display: inline-flex; }
.pdp-stepper button:hover { background: var(--cream-2); color: var(--maroon); }
.pdp-stepper span { min-width: 40px; text-align: center; font-weight: 800; font-size: 15px; }
.pdp-price { font-family: var(--serif); font-weight: 700; font-size: 28px; color: var(--maroon); }
.pdp-price-was { font-family: var(--sans); font-size: 15px; color: var(--ink-soft); text-decoration: line-through; margin-right: 8px; font-weight: 600; }
.pdp-add { flex: 1; min-width: 180px; }
.pdp-stock { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink-soft); margin-top: 18px; }
.pdp-stock .dot { width: 8px; height: 8px; border-radius: 50%; background: #4a9a5e; }

/* Tabs */
.pdp-tabs { margin: 56px 0 10px; border-top: 1px solid var(--card-line); padding-top: 8px; }
.pdp-tabnav { display: flex; gap: 28px; border-bottom: 1px solid var(--card-line); }
.pdp-tabbtn { background: none; border: none; padding: 16px 2px; font-family: var(--sans); font-weight: 700;
  font-size: 14px; color: var(--ink-soft); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: .15s; }
.pdp-tabbtn:hover { color: var(--ink); }
.pdp-tabbtn.active { color: var(--maroon); border-color: var(--maroon); }
.pdp-tabbody { padding: 22px 2px; max-width: 720px; }
.pdp-tabbody p { font-size: 15px; line-height: 1.8; color: var(--ink-soft); margin: 0; }

/* Reviews */
.pdp-reviews { margin-top: 46px; }
.pdp-section-title { font-size: 26px; margin-bottom: 22px; }
.pdp-noreview { color: var(--ink-soft); }
.pdp-review-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.pdp-review { background: var(--card); border: 1px solid var(--card-line); border-radius: var(--radius); padding: 22px; }
.pdp-review-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.pdp-review-author { font-weight: 800; font-size: 14px; }
.pdp-review h4 { font-family: var(--sans); font-size: 14px; margin-bottom: 6px; }
.pdp-review p { font-size: 13.5px; color: var(--ink-soft); line-height: 1.6; margin: 0 0 12px; }
.pdp-review-date { font-size: 12px; color: var(--ink-soft); opacity: .8; }

.pdp-related { padding: 70px 28px 0; }

@media (max-width: 860px) {
  .pdp-main { grid-template-columns: 1fr; gap: 32px; }
  .pdp-gallery { position: static; }
  .pdp-review-list { grid-template-columns: 1fr; }
  .pdp-title { white-space: normal; font-size: 30px; }
}

/* ===== Review form ===== */
.pdp-review-form { margin-top: 30px; max-width: 560px; border-top: 1px solid var(--card-line); padding-top: 24px; }
.pdp-review-form h4 { font-family: var(--serif); font-size: 20px; margin: 0 0 6px; }
.pdp-review-note { color: var(--ink-soft); font-size: 13px; margin: 0 0 10px; }
.pdp-rate { display: inline-flex; gap: 2px; margin: 6px 0 14px; }
.pdp-rate-star { background: none; border: none; padding: 2px; cursor: pointer; line-height: 0; transition: transform .1s; }
.pdp-rate-star:hover { transform: scale(1.12); }
.pdp-review-input { display: block; width: 100%; margin-bottom: 12px; padding: 11px 13px;
  border: 1px solid var(--card-line); border-radius: 9px; font-family: var(--sans); font-size: 14.5px;
  color: var(--ink); background: var(--card); }
.pdp-review-input:focus { outline: 2px solid var(--gold); border-color: transparent; }
