/* ──────────────── PRODUCT PAGE ──────────────── */

.crumb {
  display: flex;
  justify-content: space-between;
  padding: 130px var(--pad) 0;
  font-size: var(--fs-xs);
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--ink-2);
  max-width: 1500px;
  margin: 0 auto;
  flex-wrap: wrap;
  gap: 1rem;
}
.crumb a { transition: gap .3s; display: inline-flex; gap: .35rem; }
.crumb a:hover { color: var(--saffron); }
.crumb__path { color: var(--stone); }


.pdp {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(2rem, 4vw, 4rem);
  padding: clamp(2.5rem, 5vw, 4rem) var(--pad);
  max-width: 1500px;
  margin: 0 auto;
  align-items: start;
}

.pdp__info {
  position: sticky;
  top: 130px;
  display: grid;
  gap: 1.4rem;
  align-content: start;
}
.pdp__title {
  font-family: var(--f-display);
  font-size: clamp(2.6rem, 5.5vw, 5rem);
  line-height: .85;
  letter-spacing: -.01em;
  text-transform: uppercase;
  margin-top: .25rem;
}
.pdp__title em {
  font-family: var(--f-edit);
  font-style: italic;
  font-weight: 300;
  color: var(--indigo);
  text-transform: lowercase;
}
.pdp__price-row {
  display: flex; align-items: baseline; gap: 1rem;
  border-top: 1px solid var(--line);
  padding-top: 1rem;
  flex-wrap: wrap;
}
.pdp__price {
  font-family: var(--f-display);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  letter-spacing: .02em;
}
.pdp__tax {
  font-size: var(--fs-xs);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--stone);
}
.pdp__desc {
  font-family: var(--f-edit);
  font-size: var(--fs-md);
  font-weight: 300;
  font-style: italic;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 50ch;
}
.pdp__desc em { color: var(--indigo); }

.pdp__opt { display: grid; gap: .65rem; }
.pdp__opt-head {
  display: flex; justify-content: space-between;
  font-size: var(--fs-xs);
  letter-spacing: .25em;
  text-transform: uppercase;
}
.pdp__opt-val { color: var(--stone); }
.pdp__guide { color: var(--ink); border-bottom: 1px solid var(--line); padding-bottom: .15rem; }

.pdp__swatches { display: flex; gap: .5rem; }
.sw {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--sw, #000);
  position: relative;
  border: 1px solid var(--line);
  transition: transform .25s;
}
.sw::after {
  content: ''; position: absolute; inset: -5px;
  border: 1px solid transparent;
  border-radius: 50%;
  transition: border-color .25s;
}
.sw:hover { transform: scale(1.05); }
.sw.is-on::after { border-color: var(--ink); }

.pdp__sizes { display: flex; flex-wrap: wrap; gap: .4rem; }
.sz {
  min-width: 64px;
  padding: .75rem .5rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: var(--fs-xs);
  letter-spacing: .2em;
  font-weight: 600;
  transition: background .2s, color .2s, border-color .2s;
  display: inline-flex; align-items: center; justify-content: center; gap: .25rem;
}
.sz small { font-size: 9px; color: var(--saffron); letter-spacing: 0; font-weight: 500; }
.sz:hover:not(.sz--out) { border-color: var(--ink); }
.sz.is-on { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.sz.is-on small { color: var(--saffron); }
.sz--out { color: var(--stone); text-decoration: line-through; cursor: not-allowed; opacity: .55; }

.pdp__cta { display: flex; gap: .5rem; }
.pdp__add { flex: 1; justify-content: center; padding: 1.2rem 1rem; }
.pdp__wish {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  padding: 0;
  flex: 0 0 auto;
}

.pdp__feats {
  list-style: none;
  display: grid; gap: .5rem;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 1rem 0;
}
.pdp__feats li {
  display: flex; align-items: center; gap: .65rem;
  font-size: var(--fs-sm);
  color: var(--ink-2);
}
.pdp__feats span {
  width: 18px; height: 18px;
  display: grid; place-items: center;
  background: var(--saffron);
  color: var(--ink);
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
}

.pdp__acc { display: grid; gap: 0; }
.pdp__acc details {
  border-bottom: 1px solid var(--line);
}
.pdp__acc summary {
  padding: 1rem 0;
  display: flex; justify-content: space-between;
  font-size: var(--fs-xs);
  letter-spacing: .25em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: none;
  list-style: none;
}
.pdp__acc summary::-webkit-details-marker { display: none; }
.pdp__acc summary span {
  font-family: var(--f-display);
  font-size: 1.4rem;
  line-height: 1;
  transition: transform .3s;
}
.pdp__acc details[open] summary span { transform: rotate(45deg); }
.pdp__acc div {
  padding: 0 0 1.2rem;
  font-family: var(--f-edit);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-md);
  color: var(--ink-2);
  line-height: 1.55;
}


/* MEDIA */
.pdp__media {
  display: grid;
  gap: var(--gap);
}
.pdp__shot {
  position: relative;
  overflow: hidden;
  border-radius: var(--rad);
  background: var(--bone-2);
  aspect-ratio: 4/5;
}
.pdp__shot img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: contrast(1.05);
}
.pdp__shot--main { aspect-ratio: 4/4.6; }
.pdp__shot-tag {
  position: absolute;
  bottom: 1rem; left: 1rem;
  font-size: var(--fs-xs);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bone);
  background: rgba(14,14,12,.55);
  backdrop-filter: blur(8px);
  padding: .4rem .65rem;
  border-radius: 999px;
}

.pdp__double {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
}
.pdp__double .pdp__shot { aspect-ratio: 1/1.15; }

.pdp__shot--label {
  background: var(--ink);
  color: var(--bone);
  display: grid;
  place-items: center;
  aspect-ratio: 4/3;
  padding: clamp(1rem, 4vw, 3rem);
  border: 1px solid var(--ink);
}
.pdp__label {
  width: 100%;
  display: grid;
  gap: .5rem;
  font-size: var(--fs-xs);
  letter-spacing: .22em;
  text-transform: uppercase;
}
.pdp__label-row {
  display: flex; justify-content: space-between;
  border-bottom: 1px dashed rgba(239,236,228,.18);
  padding-bottom: .35rem;
}
.pdp__label-row span { color: var(--stone); }
.pdp__label-row b { font-weight: 600; color: var(--bone); }


/* STORY STRIP */
.pdp-story {
  background: var(--ink);
  color: var(--bone);
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0;
  align-items: stretch;
}
.pdp-story__l {
  padding: clamp(3rem, 8vw, 7rem) var(--pad);
  display: grid; gap: 1rem; align-content: center;
  border-right: 1px solid var(--line-d);
}
.pdp-story__title {
  font-family: var(--f-display);
  font-size: var(--fs-xl);
  line-height: .9;
  text-transform: uppercase;
  letter-spacing: -.01em;
}
.pdp-story__title em {
  font-family: var(--f-edit);
  font-style: italic;
  font-weight: 300;
  color: var(--saffron);
  text-transform: lowercase;
}
.pdp-story__l p {
  font-family: var(--f-edit);
  font-size: var(--fs-lg);
  font-weight: 300;
  line-height: 1.45;
  font-style: italic;
  color: rgba(239,236,228,.78);
  max-width: 40ch;
}
.pdp-story__deva {
  font-family: var(--f-deva);
  color: var(--saffron);
  font-style: italic;
}
.pdp-story__r img {
  width: 100%; height: 100%;
  object-fit: cover;
  min-height: 60vh;
  filter: contrast(1.05);
}


/* RECOMMENDED */
.pdp-rec {
  padding: clamp(4rem, 8vw, 7rem) var(--pad);
  background: var(--bone);
  max-width: 1500px; margin: 0 auto;
}
.pdp-rec__head {
  display: grid; gap: 1rem;
  margin-bottom: 3rem;
}
.pdp-rec__title {
  font-family: var(--f-display);
  font-size: var(--fs-xxl);
  line-height: .9;
  text-transform: uppercase;
  letter-spacing: -.01em;
}
.pdp-rec__title em {
  font-family: var(--f-edit);
  font-style: italic;
  font-weight: 300;
  color: var(--indigo);
  text-transform: lowercase;
}
.pdp-rec__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}


/* MOBILE STICKY BUY */
.pdp-buy {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  padding: .85rem var(--pad);
  background: rgba(14, 14, 12, .92);
  backdrop-filter: blur(20px);
  color: var(--bone);
  display: none;
  align-items: center;
  gap: 1rem;
  border-top: 1px solid var(--line-d);
  z-index: 90;
  transform: translateY(100%);
  transition: transform .35s ease;
}
.pdp-buy.is-shown { transform: translateY(0); }
.pdp-buy__l { display: grid; gap: .15rem; flex: 1; }
.pdp-buy__name { font-size: var(--fs-xs); letter-spacing: .2em; text-transform: uppercase; opacity: .7; }
.pdp-buy__price { font-family: var(--f-display); font-size: 1.3rem; }
.pdp-buy .btn--primary { background: var(--bone); color: var(--ink); padding: .85rem 1rem; }


@media (max-width: 1024px) {
  .pdp { grid-template-columns: 1fr; }
  .pdp__info { position: relative; top: 0; order: 2; }
  .pdp__media { order: 1; }
  .pdp-story { grid-template-columns: 1fr; }
  .pdp-story__l { border-right: 0; border-bottom: 1px solid var(--line-d); }
  .pdp-rec__grid { grid-template-columns: 1fr 1fr; }
  .pdp-buy { display: flex; }
  body { padding-bottom: 76px; }
}
@media (max-width: 600px) {
  .pdp-rec__grid { grid-template-columns: 1fr; }
  .pdp__double { grid-template-columns: 1fr; }
}
