/*
  idols-product.css
  Idol-specific overrides layered on top of metal-strips-product.css.
  Load order required:
  1) /product/assets/metal-strips-product.css
  2) /product/assets/idols-product.css
*/

.vgs-buy{
  display:grid;
  gap:10px;
}
.vgs-title{
  margin:0;
}
.vgs-top-specs{
  font-size:15px;
  line-height:1.45;
  color:#374151;
  font-weight:700;
}
.vgs-sub{
  margin:0;
  font-size:14px;
  line-height:1.55;
  color:var(--vgs-muted);
}
.vgs-price{
  margin:4px 0 0;
  display:flex;
  align-items:baseline;
  gap:10px;
  flex-wrap:wrap;
}
.vgs-price-now{
  font-size:44px;
  line-height:1;
  letter-spacing:-.6px;
}
.vgs-price-mrp{
  font-size:28px;
  line-height:1;
}
.vgs-off{
  padding:5px 11px;
  border-radius:999px;
  border:1px solid rgba(21,128,61,.28);
  background:rgba(21,128,61,.12);
  color:#166534;
  font-size:22px;
  line-height:1;
  font-weight:900;
}
.vgp-stock{
  margin-top:2px;
  display:flex;
  align-items:center;
  gap:7px;
  font-size:14px;
  font-weight:700;
  color:#1f2937;
}
.vgp-stock::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  flex:0 0 auto;
}
.vgp-stock.in::before{
  background:#16a34a;
}
.vgp-stock.out::before{
  background:#b91c1c;
}
.vgs-short-note{
  padding:8px 10px;
  border:1px solid var(--vgs-border);
  border-radius:10px;
  background:#fff;
  color:#475569;
  font-size:13px;
  line-height:1.5;
}

.vgs-variant-compare{
  margin-top:8px;
  padding-top:12px;
  border-top:1px solid var(--vgs-border);
}
.vgs-variant-compare h3{
  margin:0;
  font-size:15px;
  color:var(--vgs-ink);
  font-weight:900;
  letter-spacing:.2px;
  text-transform:uppercase;
}
.vgs-variant-note{
  margin:6px 0 10px;
  font-size:13px;
  color:var(--vgs-muted);
}
.vgs-variant-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:9px;
}
.vgs-variant-card{
  display:block;
  border:1px solid var(--vgs-border);
  border-radius:12px;
  background:#fff;
  padding:12px 14px;
  min-width:0;
  text-decoration:none;
  color:inherit;
  transition:border-color .16s ease, box-shadow .16s ease, background-color .16s ease;
}
.vgs-variant-card:hover{
  border-color:rgba(198,93,0,.35);
  background:var(--vgs-soft);
}
.vgs-variant-card.is-current{
  border-color:#1e3a5f;
  background:#f8fafc;
  box-shadow:0 0 0 1px rgba(30,58,95,.22) inset;
}
.vgs-variant-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.vgs-variant-left{
  min-width:0;
  display:grid;
  gap:2px;
}
.vgs-variant-name{
  font-weight:900;
  font-size:16px;
  line-height:1.25;
  color:var(--vgs-ink);
  overflow-wrap:anywhere;
}
.vgs-variant-meta{
  font-size:13px;
  line-height:1.4;
  color:var(--vgs-muted);
  overflow-wrap:anywhere;
}
.vgs-variant-right{
  text-align:right;
  flex:0 0 auto;
  display:grid;
  justify-items:end;
}
.vgs-variant-price{
  font-size:24px;
  line-height:1;
  font-weight:900;
  color:var(--vgs-ink);
}
.vgs-variant-mrp{
  margin-top:3px;
  display:block;
  text-decoration:line-through;
  color:var(--vgs-muted);
  font-size:15px;
  line-height:1.1;
  font-weight:700;
}
.vgs-variant-pill{
  margin-top:8px;
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid #1e3a5f;
  background:#eff6ff;
  color:#1e3a5f;
  font-size:12px;
  font-weight:900;
}

.vgs-variants{
  margin-top:8px;
  padding-top:12px;
  border-top:1px solid var(--vgs-border);
}
.vgs-variants h3{
  margin:0 0 8px;
  font-size:15px;
  color:var(--vgs-ink);
  font-weight:900;
  letter-spacing:.2px;
  text-transform:uppercase;
}
.vgs-meta{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:8px;
}
.vgs-meta div{
  padding:10px 11px;
  border:1px solid var(--vgs-border);
  border-radius:10px;
  background:#fff;
  font-size:16px;
  line-height:1.25;
  font-weight:800;
  color:var(--vgs-ink);
  box-shadow:none;
}
.vgs-meta small{
  display:block;
  margin-bottom:5px;
  color:var(--vgs-muted);
  font-size:11px;
  line-height:1;
  letter-spacing:.05em;
  text-transform:uppercase;
  font-weight:800;
}

.vgp-emotion-line{
  margin:8px 0 0;
  padding:10px 12px;
  border:1px solid var(--vgs-border);
  border-left:3px solid #1e3a5f;
  border-radius:10px;
  background:#fff;
  color:#334155;
  font-size:15px;
  line-height:1.55;
  font-weight:600;
}

.vgp-buybox{
  margin-top:8px;
  padding-top:12px;
  border-top:1px solid var(--vgs-border);
}
.vgs-buy-actions{
  display:grid;
  gap:10px;
}
.vgs-qty-block{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.vgs-qty-title{
  margin:0;
  color:var(--vgs-ink);
  font-size:14px;
  line-height:1;
  font-weight:800;
}
.vgp-qty{
  gap:0;
  border:1px solid var(--vgs-border);
  border-radius:12px;
  overflow:hidden;
  background:#fff;
}
.vgp-qtybtn{
  border:0;
  border-radius:0;
  min-width:42px;
  min-height:42px;
  font-size:24px;
  line-height:1;
  color:var(--vgs-ink);
  background:#fff;
}
.vgp-qtybtn:hover{
  background:var(--vgs-soft);
}
.vgp-qtyinp{
  border:0;
  border-left:1px solid var(--vgs-border);
  border-right:1px solid var(--vgs-border);
  border-radius:0;
  width:56px;
  min-height:42px;
  font-size:22px;
  line-height:1;
  font-weight:900;
  text-align:center;
  color:var(--vgs-ink);
}
.vgs-cta{
  margin-top:0;
}
.vgs-buy .vgs-cta > .vgp-cta{
  background:#fff;
  border:1px solid #1e3a5f;
  color:#1e3a5f;
  box-shadow:none;
}
.vgs-buy .vgs-cta .vgp-cta-primary{
  background:#c65d00;
  border-color:#c65d00;
  color:#fff;
  box-shadow:0 10px 20px rgba(198,93,0,.2);
}

.vgs-consult-cta{
  margin-top:10px;
  padding:12px;
  border:1px solid #d1d5db;
  border-radius:12px;
  background:#f3f4f6;
}
.vgs-consult-title{
  font-weight:800;
  color:#111827;
  font-size:14px;
}
.vgs-consult-text{
  margin:6px 0 10px;
  color:#374151;
  font-size:13px;
  line-height:1.5;
}
.vgs-consult-link{
  display:inline-block;
  text-decoration:none;
  color:#1f2937;
  border:1px solid #9ca3af;
  background:#fff;
  border-radius:10px;
  font-weight:700;
  font-size:13px;
  padding:7px 11px;
}
.vgs-consult-link:hover{background:#f9fafb;}

.vgs-trust{
  margin-top:8px;
}
.vgs-share{
  margin-top:8px;
  padding-top:10px;
  border-top:1px solid var(--vgs-border);
  gap:7px;
}
.vgs-share > .vgs-share-label{
  font-size:10px;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.vgs-share a{
  font-size:11px;
  padding:4px 8px;
  color:#475569;
}

/* Legacy section blocks used by idol pages */
.vgp-section{
  margin:24px 0;
}
.vgp-section h2{
  margin:0 0 12px;
  font-size:28px;
  font-weight:900;
  color:#1E3A5F;
  font-family:"Playfair Display","Cinzel","Noto Sans Devanagari",serif;
}
.vgp-section p{
  margin:0 0 10px;
  color:var(--vgs-ink);
  line-height:1.75;
  font-size:18px;
}
.vgp-section ul{
  margin:8px 0 0;
  padding-left:18px;
  color:var(--vgs-ink);
}
.vgp-section li{margin-bottom:6px;font-size:18px;}
.vgp-section details{
  border:1px solid var(--vgs-border);
  border-radius:12px;
  background:#fff;
  margin-bottom:10px;
  padding:12px 14px;
}
.vgp-section summary{
  cursor:pointer;
  font-weight:800;
  color:var(--vgs-ink);
}

/* Idol media tone + sticky offset */
.vgp-hero{
  border-radius:16px;
  overflow:hidden;
  background:#f3f4f6;
}

@media (min-width: 1280px){
  .vgs-grid > .vgp-gallery{
    position: sticky;
    top: 78px;
    align-self: start;
    max-height: none;
    overflow: visible;
  }
  .vgs-grid > .vgp-gallery #vgpHeroBox{
    position: relative;
    top: auto;
  }
}
@media (max-width: 980px){
  .vgs-price-now{font-size:38px;}
  .vgs-price-mrp{font-size:24px;}
  .vgs-off{font-size:18px;}
}
@media (max-width: 760px){
  .vgs-variant-head{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }
  .vgs-variant-right{
    text-align:left;
    justify-items:start;
  }
  .vgs-price-now{font-size:34px;}
  .vgs-price-mrp{font-size:21px;}
  .vgs-meta{
    grid-template-columns:1fr 1fr;
  }
}
@media (max-width: 560px){
  .vgs-qty-block{
    flex-direction:column;
    align-items:flex-start;
  }
  .vgs-cta{
    flex-direction:column;
  }
  .vgs-cta .vgp-cta,
  .vgs-cta .pdp-main-product-block__buy-now{
    width:100%;
  }
}
