/* =============================================
   product.css — Product Detail + Animations
   ============================================= */

/* HEADER */
.pv-header{display:flex;align-items:center;justify-content:space-between;padding:0 4px;}
.back-btn{background:none;border:none;color:white;font-size:13px;cursor:pointer;padding:4px 8px;font-family:'DM Sans',sans-serif;font-weight:500;}
.pv-brand{font-family:'Cormorant Garamond',serif;font-size:16px;color:white;font-weight:600;}
.cart-icon-btn{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);border-radius:20px;color:white;padding:4px 12px;font-size:13px;cursor:pointer;position:relative;font-family:'DM Sans',sans-serif;}
.cart-badge{background:#FF4444;color:white;border-radius:50%;font-size:10px;font-weight:700;padding:1px 5px;margin-left:2px;display:none;}

/* PAGE LAYOUT */
.pv-wrap{max-width:900px;margin:0 auto;}
@media(min-width:700px){.pv-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:16px;align-items:start;}}

/* GALLERY */
.pv-gallery{background:var(--cream2);}
.pv-main-img-wrap{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--cream2);}
.pv-main-img-wrap img{width:100%;height:100%;object-fit:cover;cursor:zoom-in;transition:transform .3s;}
.pv-main-img-wrap img:hover{transform:scale(1.02);}
.pv-thumbs{display:flex;gap:6px;padding:8px;overflow-x:auto;scrollbar-width:none;background:white;}
.pv-thumbs::-webkit-scrollbar{display:none;}
.pv-thumb{width:60px;height:60px;object-fit:cover;border-radius:6px;border:2px solid var(--border);cursor:pointer;flex-shrink:0;transition:border-color .2s;}
.pv-thumb.active{border-color:var(--green);}

/* INFO */
.pv-info{padding:14px;}
.pv-badges{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px;}
.pv-badge{background:var(--gp);color:var(--green);font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;border:1px solid var(--border);}
.pv-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:6px;}
@media(min-width:700px){.pv-title{font-size:24px;}}
.pv-social{font-size:11px;color:#E67E22;font-weight:600;margin-bottom:10px;}
.pv-price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:14px;flex-wrap:wrap;}
.pv-price{font-size:28px;font-weight:700;color:var(--green);}
.pv-was{font-size:16px;color:#bbb;text-decoration:line-through;}
.pv-disc{background:#FFF3CD;color:var(--gold);font-size:12px;font-weight:700;padding:2px 8px;border-radius:4px;border:1px solid #FFE08A;}

/* QTY */
.qty-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.qty-label{font-size:13px;color:var(--text2);font-weight:500;}
.qty-btn{width:34px;height:34px;border:1.5px solid var(--border);border-radius:8px;background:white;font-size:18px;cursor:pointer;color:var(--green);display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;transition:background .2s;}
.qty-btn:hover{background:var(--gp);}
.qty-val{font-size:16px;font-weight:600;color:var(--text);min-width:24px;text-align:center;}

/* CTA */
.pv-cta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
.btn-cart{background:white;border:2px solid var(--green);color:var(--green);border-radius:10px;padding:13px 8px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s;}
.btn-cart:hover{background:var(--gp);}
.btn-order{background:var(--green);border:2px solid var(--green);color:white;border-radius:10px;padding:13px 8px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s;}
.btn-order:hover{background:var(--gl);}

/* SECTIONS */
.pv-section{margin-bottom:16px;border-top:1px solid var(--border);padding-top:14px;}
.pv-section-title{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;color:var(--green);margin-bottom:8px;}
.pv-desc{font-size:13px;color:var(--text2);line-height:1.8;}
.pv-benefits{padding-left:0;list-style:none;}
.pv-benefits li{font-size:13px;color:var(--text2);line-height:1.7;padding:4px 0;border-bottom:1px solid rgba(200,223,192,.4);display:flex;gap:8px;}
.pv-benefits li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0;}
.pv-how{font-size:13px;color:var(--text2);line-height:1.8;}
.pv-delivery{background:var(--gp);border-radius:10px;padding:12px 14px;margin-bottom:20px;}
.pv-del-item{display:flex;gap:8px;font-size:12px;color:var(--text2);padding:4px 0;}

/* =============================================
   ANIMATED FACEBOOK REACT SYSTEM
   ============================================= */
.fb-react-wrap{position:relative;margin-bottom:14px;}

.fb-react-bar{display:flex;align-items:center;justify-content:space-between;background:var(--cream2);border-radius:20px;padding:6px 12px;}

.fb-react-summary{display:flex;align-items:center;gap:6px;}
.fb-react-emojis{display:flex;}
.fb-react-emojis span{width:20px;height:20px;border-radius:50%;border:2px solid white;display:flex;align-items:center;justify-content:center;font-size:11px;margin-left:-4px;background:white;box-shadow:0 1px 3px rgba(0,0,0,.15);}
.fb-react-emojis span:first-child{margin-left:0;}
.fb-react-count{font-size:12px;color:var(--text2);}

.fb-react-trigger{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;font-size:12px;color:var(--text2);font-family:'DM Sans',sans-serif;padding:4px 8px;border-radius:12px;transition:background .2s;position:relative;}
.fb-react-trigger:hover{background:rgba(0,0,0,.05);}
.fb-react-trigger .my-emoji{font-size:14px;}

/* REACT POPUP */
.fb-react-popup{
  position:absolute;
  bottom:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%) scale(0.7);
  transform-origin:bottom center;
  background:white;
  border-radius:40px;
  padding:8px 10px;
  display:flex;
  gap:4px;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  opacity:0;
  pointer-events:none;
  transition:all .2s cubic-bezier(.34,1.56,.64,1);
  z-index:100;
  white-space:nowrap;
}

.fb-react-popup.visible{
  opacity:1;
  pointer-events:all;
  transform:translateX(-50%) scale(1);
}

/* Individual reaction buttons */
.fb-rxn{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  cursor:pointer;
  padding:2px;
}

.fb-rxn .rxn-emoji{
  font-size:28px;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1);
  display:block;
  line-height:1;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));
}

.fb-rxn:hover .rxn-emoji{
  transform:scale(1.5) translateY(-8px);
  animation:wobble .4s ease;
}

.fb-rxn .rxn-label{
  font-size:9px;
  font-weight:600;
  color:var(--text2);
  position:absolute;
  bottom:-16px;
  left:50%;
  transform:translateX(-50%);
  white-space:nowrap;
  opacity:0;
  transition:opacity .15s;
  background:rgba(0,0,0,.7);
  color:white;
  padding:1px 5px;
  border-radius:6px;
}

.fb-rxn:hover .rxn-label{opacity:1;}
.fb-rxn.selected .rxn-emoji{animation:pulse-react .3s ease;}

@keyframes wobble{
  0%{transform:scale(1.5) translateY(-8px) rotate(0deg);}
  25%{transform:scale(1.5) translateY(-10px) rotate(-8deg);}
  50%{transform:scale(1.5) translateY(-8px) rotate(8deg);}
  75%{transform:scale(1.5) translateY(-10px) rotate(-4deg);}
  100%{transform:scale(1.5) translateY(-8px) rotate(0deg);}
}

@keyframes pulse-react{
  0%{transform:scale(1);}
  50%{transform:scale(1.3);}
  100%{transform:scale(1);}
}

/* Flying emoji animation */
.flying-emoji{
  position:fixed;
  font-size:24px;
  pointer-events:none;
  z-index:9999;
  animation:flyUp 1s ease forwards;
}

@keyframes flyUp{
  0%{opacity:1;transform:translateY(0) scale(1);}
  100%{opacity:0;transform:translateY(-120px) scale(0.5);}
}

/* =============================================
   COMMENT SYSTEM
   ============================================= */
.comment-section{margin:0 14px 20px;border-top:1px solid var(--border);padding-top:14px;}
.comment-title{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--green);font-weight:600;margin-bottom:12px;}

.comment-locked{background:var(--cream2);border-radius:10px;padding:16px;text-align:center;border:1px dashed var(--border);}
.comment-locked p{font-size:12px;color:var(--text2);margin-bottom:10px;}
.comment-locked .buy-to-comment{background:var(--green);color:white;border:none;border-radius:8px;padding:9px 18px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;}

.comment-form{margin-bottom:14px;display:none;}
.comment-form.visible{display:block;}
.comment-input{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:10px 12px;font-family:'DM Sans',sans-serif;font-size:13px;resize:none;height:72px;outline:none;transition:border-color .2s;}
.comment-input:focus{border-color:var(--gl);}
.comment-submit{background:var(--green);color:white;border:none;border-radius:8px;padding:8px 18px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;margin-top:6px;}

.comment-list{}
.comment-item{display:flex;gap:10px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(200,223,192,.4);}
.comment-avatar{width:34px;height:34px;border-radius:50%;background:var(--green);color:white;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;}
.comment-body{flex:1;}
.comment-name{font-size:12px;font-weight:600;color:var(--text);margin-bottom:2px;}
.comment-text{font-size:12px;color:var(--text2);line-height:1.6;}
.comment-time{font-size:10px;color:#bbb;margin-top:2px;}
.comment-verified{font-size:9px;color:var(--green);background:var(--gp);padding:1px 5px;border-radius:4px;margin-left:4px;}

/* =============================================
   RELATED PRODUCTS
   ============================================= */
.related-section{padding:0 0 28px;}
.related-title{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;color:var(--green);padding:14px 12px 8px;}
.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 8px;}
@media(min-width:600px){.related-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.related-grid{grid-template-columns:repeat(4,1fr);}}

.related-card{background:white;border-radius:12px;overflow:hidden;border:1px solid var(--border);cursor:pointer;transition:box-shadow .2s;}
.related-card:hover{box-shadow:0 4px 14px rgba(45,106,79,.14);}
.related-card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;max-height:150px;}
.related-card-body{padding:7px 8px 9px;}
.related-card-name{font-size:10px;font-weight:600;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px;line-height:1.35;}
.related-card-price{font-size:12px;font-weight:700;color:var(--green);}

/* =============================================
   CART DRAWER
   ============================================= */
.cart-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1500;justify-content:flex-end;}
.cart-overlay.open{display:flex;}
.cart-drawer{background:white;width:100%;max-width:360px;height:100%;display:flex;flex-direction:column;animation:slideRight .25s ease;}
@keyframes slideRight{from{transform:translateX(100%);}to{transform:translateX(0);}}
.cart-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border);background:var(--green);color:white;}
.cart-header h3{font-size:16px;font-weight:600;font-family:'Cormorant Garamond',serif;}
.cart-header button{background:rgba(255,255,255,.2);border:none;color:white;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:14px;}
.cart-items{flex:1;overflow-y:auto;padding:12px;}
.cart-empty{text-align:center;color:var(--text2);padding:40px 20px;font-size:14px;line-height:2;}
.cart-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.cart-item img{width:64px;height:64px;object-fit:cover;border-radius:8px;flex-shrink:0;}
.cart-item-info{flex:1;}
.cart-item-name{font-size:12px;font-weight:600;color:var(--text);margin-bottom:3px;line-height:1.3;}
.cart-item-price{font-size:12px;color:var(--green);font-weight:600;margin-bottom:6px;}
.cart-item-controls{display:flex;align-items:center;gap:6px;}
.cart-item-controls button{background:var(--cream2);border:1px solid var(--border);border-radius:6px;width:24px;height:24px;font-size:14px;cursor:pointer;color:var(--green);display:flex;align-items:center;justify-content:center;}
.cart-item-controls span{font-size:13px;font-weight:600;min-width:18px;text-align:center;}
.cart-remove{background:#FFF0F0!important;border-color:#FFCCCC!important;color:#CC0000!important;margin-left:4px;}
.cart-footer{padding:12px;border-top:1px solid var(--border);}
.cart-total{font-size:16px;color:var(--text);margin-bottom:10px;text-align:right;}
.cart-total strong{color:var(--green);font-size:18px;}
.cart-checkout-btn{width:100%;background:var(--green);color:white;border:none;border-radius:10px;padding:14px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;margin-bottom:8px;}
.cart-continue{display:block;text-align:center;font-size:12px;color:var(--text2);text-decoration:none;padding:4px;}

/* CART TOAST */
.cart-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--green);color:white;padding:10px 20px;border-radius:20px;font-size:13px;font-weight:500;font-family:'DM Sans',sans-serif;opacity:0;transition:all .3s;z-index:3000;white-space:nowrap;}
.cart-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* LIGHTBOX */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:2000;align-items:center;justify-content:center;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:85vh;border-radius:8px;object-fit:contain;}
.lb-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.15);border:none;border-radius:50%;width:36px;height:36px;font-size:18px;color:white;cursor:pointer;display:flex;align-items:center;justify-content:center;}

