.product-detail-modal{
  position:fixed;
  inset:0;
  z-index:1200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.product-detail-modal.is-open{
  display:flex;
}

.product-detail-backdrop{
  position:absolute;
  inset:0;
  background:rgba(14,6,4,.72);
  backdrop-filter:blur(8px);
}

.product-detail-dialog{
  position:relative;
  width:min(1040px,94vw);
  max-height:88vh;
  overflow:auto;
  background:#FFF9EF;
  color:#1C0D08;
  border:1px solid rgba(196,154,40,.36);
  box-shadow:0 34px 90px rgba(0,0,0,.42);
}

.product-detail-close{
  position:sticky;
  top:12px;
  float:right;
  z-index:2;
  width:42px;
  height:42px;
  margin:12px 12px 0 0;
  border:1px solid rgba(28,13,8,.2);
  background:#1C0D08;
  color:#F5EDE0;
  font-size:1.25rem;
  cursor:pointer;
}

.product-detail-inner{
  padding:34px;
}

.product-detail-hero{
  display:grid;
  grid-template-columns:minmax(220px,330px) minmax(0,1fr);
  gap:28px;
  align-items:center;
  padding-bottom:26px;
  border-bottom:1px solid rgba(28,13,8,.12);
}

.product-detail-media{
  min-height:300px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:radial-gradient(circle at 50% 24%,#fff 0,#F3E6D1 62%,#D8C29C 100%);
}

.product-detail-media img{
  width:100%;
  max-height:320px;
  object-fit:contain;
  filter:drop-shadow(0 18px 24px rgba(28,13,8,.20));
}

.product-detail-kicker{
  display:inline-flex;
  margin-bottom:10px;
  padding:5px 9px;
  background:#1C0D08;
  color:#F5EDE0;
  font-size:.72rem;
  font-weight:800;
}

.product-detail-title{
  margin:0 0 10px;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3.4rem);
  line-height:1;
  color:#1C0D08;
}

.product-detail-copy{
  margin:0 0 18px;
  color:rgba(28,13,8,.78);
  line-height:1.72;
}

.product-detail-list{
  display:grid;
  gap:7px;
  margin:0 0 18px;
  padding:0;
  list-style:none;
}

.product-detail-list li{
  position:relative;
  padding-left:16px;
  color:rgba(28,13,8,.78);
  font-size:.9rem;
  line-height:1.5;
}

.product-detail-list li::before{
  content:'';
  position:absolute;
  left:0;
  top:.65em;
  width:6px;
  height:6px;
  background:#C49A28;
}

.product-detail-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.product-detail-facts{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:26px 0;
}

.product-detail-fact{
  background:#1C0D08;
  color:#F5EDE0;
  padding:15px;
}

.product-detail-fact span{
  display:block;
  margin-bottom:5px;
  color:#D4AA38;
  font-size:.72rem;
  font-weight:800;
}

.product-detail-fact strong{
  font-size:.95rem;
  line-height:1.35;
}

.product-detail-source{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:7px 12px;
  margin:-8px 0 24px;
  padding:14px;
  background:rgba(28,13,8,.05);
  border:1px solid rgba(28,13,8,.12);
  color:rgba(28,13,8,.76);
  font-size:.78rem;
  line-height:1.45;
}

.product-detail-source span{
  overflow-wrap:anywhere;
}

.product-detail-source strong{
  color:#1C0D08;
}

.product-detail-accordions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.product-detail-accordions details{
  background:#fff;
  border:1px solid rgba(28,13,8,.13);
}

.product-detail-accordions summary{
  cursor:pointer;
  padding:15px 17px;
  color:#1C0D08;
  font-weight:800;
}

.product-detail-accordions p{
  margin:0;
  padding:0 17px 17px;
  color:rgba(28,13,8,.76);
  line-height:1.68;
}

.product-detail-note{
  margin-top:18px;
  padding:12px 14px;
  background:rgba(180,64,32,.09);
  color:#6A2A16;
  line-height:1.55;
}

.product-detail-benefits{
  margin-top:20px;
  padding:18px;
  background:#fff;
  border:1px solid rgba(28,13,8,.12);
}

.product-detail-benefits h3{
  margin:0 0 12px;
  color:#1C0D08;
  font-size:.82rem;
  letter-spacing:.12em;
  text-transform:uppercase;
}

@media(max-width:760px){
  .product-detail-modal{
    align-items:flex-end;
    padding:0;
  }

  .product-detail-dialog{
    width:100%;
    max-height:88vh;
    border-radius:14px 14px 0 0;
  }

  .product-detail-inner{
    padding:24px 18px 28px;
  }

  .product-detail-hero,
  .product-detail-facts,
  .product-detail-source,
  .product-detail-accordions{
    grid-template-columns:1fr;
  }

  .product-detail-media{
    min-height:220px;
  }
}
