/* ═══════════════════════════════════════════════════════
   VAYGO Modular Commerce v3.2
   Theme accent colors: #D9F055 (lime) | #1743D7 (blue) | #E47325 (orange)
   ═══════════════════════════════════════════════════════ */
:root{
  --vaygo-thumb-gap:8px;--vaygo-thumb-radius:10px;
  --vaygo-thumb-active-border:#111;--vaygo-thumb-active-bg:transparent;
  --vaygo-thumb-inactive-border:transparent;--vaygo-thumb-inactive-bg:transparent;
  --vaygo-var-gap:10px;--vaygo-var-radius:12px;
  --vaygo-var-active-border:#111;--vaygo-var-active-bg:transparent;
  --vaygo-var-inactive-border:transparent;--vaygo-var-inactive-bg:transparent;
  /* CYOB core — separate from wings */
  --vaygo-cyob-core-gap:10px;--vaygo-cyob-core-radius:12px;
  --vaygo-cyob-core-active-border:#111;--vaygo-cyob-core-active-bg:transparent;
  --vaygo-cyob-core-inactive-border:transparent;--vaygo-cyob-core-inactive-bg:transparent;
  /* CYOB wings — separate from core */
  --vaygo-cyob-wings-gap:10px;--vaygo-cyob-wings-radius:12px;
  --vaygo-cyob-wings-active-border:#111;--vaygo-cyob-wings-active-bg:transparent;
  --vaygo-cyob-wings-inactive-border:transparent;--vaygo-cyob-wings-inactive-bg:transparent;
  --vaygo-gallery-main-height:400px;--vaygo-gallery-main-height-mobile:400px;
  /* Drawer */
  --vd-w:550px;--vd-bg:#fff;--vd-overlay:rgba(0,0,0,.46);--vd-z:99999;
  --vd-green:#16a34a;--vd-lime:#D9F055;--vd-blue:#1743D7;--vd-orange:#E47325;
}

/* ─── Slots ─── */
.vaygo-pdp-slot{width:100%;min-width:0;}
.vaygo-gallery,.vaygo-stepper,.vaygo-details,.vaygo-wings-used,
.vaygo-cyob-cores,.vaygo-cyob-wings,.vaygo-actions,.vaygo-actions-combined{width:100%;}

/* ─── Gallery main ─── */
.vaygo-gallery-link{display:block;width:100%;height:100%;line-height:0;text-decoration:none;}
.vaygo-gallery-main-wrap{position:relative;width:100%;height:var(--vaygo-gallery-main-height);overflow:hidden;background:transparent;}
.vaygo-gallery-main{display:block;width:100%;height:100%;max-width:none;transition:opacity .18s ease;}
.vaygo-gallery-main.is-contain{object-fit:contain;height:inherit;}
.vaygo-gallery-main.is-cover{object-fit:cover;height:inherit;}

/* Shimmer overlay */
.vaygo-gallery-loading-shimmer{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.55) 50%,rgba(255,255,255,0) 100%);
  background-size:200% 100%;animation:vaygo-shimmer 1.2s ease-in-out infinite;
  pointer-events:none;z-index:2;
}
@keyframes vaygo-shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
/* Tote-loading transitional state: when wing clicked but tote not yet resolved.
   Hides any ::before bg the theme applies on core-loaded, preventing overlap. */
.is-cyob-tote-loading::before{display:none!important;opacity:0!important;}
.vaygo-gallery-main-wrap.vaygo-skeleton{
  background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);
  background-size:200% 100%;animation:vaygo-shimmer 1.4s ease-in-out infinite;border-radius:8px;
}

/* ─── Thumbs & Variations ─── */
.vaygo-thumb-img,.vaygo-variation-img,.vaygo-placeholder-wing{display:block;width:100%;height:100%;max-width:100%;box-sizing:border-box;object-fit:cover;}
img.vaygo-thumb-img{object-fit:cover;height:100%;}
.vaygo-gallery-thumbs,.vaygo-variations{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--vaygo-thumb-gap);}
.vaygo-variations{gap:var(--vaygo-var-gap);}
.vaygo-thumb,.vaygo-variation{
  box-sizing:border-box;
  aspect-ratio:1/1;
  appearance:none;-webkit-appearance:none;display:block;padding:0;margin:0;
  cursor:pointer;overflow:hidden;line-height:0;
  border-radius:var(--vaygo-var-radius);
  border:1px solid var(--vaygo-var-inactive-border);
  background:var(--vaygo-var-inactive-bg);
  transition:border-color .15s ease,transform .12s ease;
}
.vaygo-thumb{border-color:var(--vaygo-thumb-inactive-border);background:var(--vaygo-thumb-inactive-bg);border-radius:var(--vaygo-thumb-radius);}
.vaygo-thumb.is-active,.vaygo-thumb[data-active="1"]{border-color:var(--vaygo-thumb-active-border);background:var(--vaygo-thumb-active-bg);}
.vaygo-variation.is-active,.vaygo-variation[data-active="1"]{border-color:var(--vaygo-var-active-border);background:var(--vaygo-var-active-bg);}

/* CYOB cores — own CSS vars, own gap/radius */
.vaygo-cyob-cores{gap:var(--vaygo-cyob-core-gap);}
.vaygo-cyob-cores .vaygo-variation{
  border-radius:var(--vaygo-cyob-core-radius);
  border-color:var(--vaygo-cyob-core-inactive-border);
  background:var(--vaygo-cyob-core-inactive-bg);
}
.vaygo-cyob-cores .vaygo-variation.is-active,
.vaygo-cyob-cores .vaygo-variation[data-active="1"]{
  border-color:var(--vaygo-cyob-core-active-border);
  background:var(--vaygo-cyob-core-active-bg);
}

/* CYOB wings — own CSS vars, own gap/radius */
.vaygo-cyob-wings{gap:var(--vaygo-cyob-wings-gap);}
.vaygo-cyob-wings .vaygo-variation{
  border-radius:var(--vaygo-cyob-wings-radius);
  border-color:var(--vaygo-cyob-wings-inactive-border);
  background:var(--vaygo-cyob-wings-inactive-bg);
}
.vaygo-cyob-wings .vaygo-variation.is-active,
.vaygo-cyob-wings .vaygo-variation[data-active="1"]{
  border-color:var(--vaygo-cyob-wings-active-border);
  background:var(--vaygo-cyob-wings-active-bg);
}

.vaygo-variation-img{padding:4px;}
.vaygo-visited-tote-card,.vaygo-variation{text-align:left;aspect-ratio:1/1;}
.vaygo-visited-tote-card .vaygo-variation-img{padding:0;}
.vaygo-visited-totes{width:100%;}
.vaygo-visited-totes-grid{width:100%;}

/* ─── Actions ─── */
.vaygo-action-row{display:flex;align-items:stretch;gap:0;flex-wrap:nowrap;width:100%;overflow:hidden;}
/* is-summary-full (tote paired) and is-single-product (core/wings) share the same bordered pill */
.vaygo-action-row.is-summary-full,.vaygo-action-row.is-single-product{border:2px solid #202020;/* border-radius set inline from settings */}
.vaygo-action-row.is-summary-full .vaygo-cta,.vaygo-action-row.is-single-product .vaygo-cta{flex:1 1 auto;border-top-left-radius:0!important;border-bottom-left-radius:0!important;}
.vaygo-action-row.is-summary-partial .vaygo-cta{width:100%!important;}

/* ─── Attrs ─── */
.vaygo-attr-row{display:flex;gap:16px;align-items:flex-start;margin:6px 0;}
.vaygo-attr-key{font-weight:600;flex:0 0 auto;}
.vaygo-attr-val{flex:1 1 auto;min-width:0;}

/* Lightbox feed */
.vaygo-gallery-thumbs a.vaygo-thumb{display:block;text-decoration:none;}
.vaygo-wings-used-label{font-weight:600;margin-right:6px;}

/* ─── Summary ─── */
.vaygo-summary-box{width:100%;margin:0 0 18px;}
.vaygo-summary-top{display:flex;justify-content:flex-start;align-items:flex-start;gap:18px;margin-bottom:18px;}
.vaygo-summary-top-left{color:#7b7b7b;font-size:14px;line-height:1.4;}
.vaygo-summary-price .price{display:flex;flex-direction:column;align-items:flex-end;gap:2px;}
.vaygo-summary-price .amount{font-size:20px;font-weight:700;color:#111;}
.vaygo-summary-price del .amount,.vaygo-summary-price del{font-size:16px;font-weight:600;color:#9b9b9b;}
.vaygo-summary-price ins{text-decoration:none;}
.vaygo-summary-full{position:relative;}
.vaygo-summary-parent{display:flex;align-items:center;gap:14px;margin-bottom:0;}
.vaygo-summary-parent-left{display:flex;align-items:center;gap:14px;min-width:0;}
.vaygo-summary-parent-name{font-size:16px;line-height:1.35;color:#111;min-width:0;}
.vaygo-summary-tree{position:relative;margin-left:18px;padding-left:38px;}
.vaygo-summary-tree:before{content:"";position:absolute;left:7px;top:0;bottom:30px;width:1px;background:#d5d5d5;}
.vaygo-summary-child{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:22px;}
.vaygo-summary-child:last-child{margin-bottom:0;}
.vaygo-summary-child-line{position:absolute;left:-30px;top:22px;width:30px;height:1px;background:#d5d5d5;}
.vaygo-summary-child-left{display:flex;align-items:center;gap:14px;min-width:0;}
img.vaygo-summary-child-img,img.vaygo-summary-parent-img{width:46px;height:46px;object-fit:contain;border:1px solid #d5d5d5;border-radius:7px;background:#fff;flex:0 0 46px;}
img.vaygo-summary-child-img{padding:4px;}
.vaygo-summary-price del,.vaygo-summary-price ins{max-height:24px;}
.vaygo-summary-child-name{font-size:14px;line-height:1.35;color:#111;min-width:0;}
/* Show subtotal, discount, and final — hide anything else */
.vaygo-summary-total-row:not(.is-final):not(.is-discount):not(.is-subtotal){display:none!important;}
.vaygo-summary-child-mid,.vaygo-summary-single-mid{display:flex;align-items:center;justify-content:center;}
.vaygo-summary-child-right,.vaygo-summary-single-right{display:flex;align-items:flex-start;gap:16px;}
.vaygo-summary-child-right .vaygo-summary-price .price,.vaygo-summary-single-right .vaygo-summary-price .price{align-items:flex-end;}
.vaygo-summary-child-right .vaygo-summary-price .amount,.vaygo-summary-single-right .vaygo-summary-price .amount,.vaygo-summary-child-right del .amount,.vaygo-summary-single-right del .amount{font-size:14px;}
.vaygo-summary-row-qty{display:flex;align-items:center;gap:26px;}
.vaygo-summary-row-qty-btn,.vaygo-summary-child-remove{appearance:none;-webkit-appearance:none;border:0;background:transparent;cursor:pointer;padding:0;line-height:1;}
.vaygo-summary-row-qty-btn{color:#111;font-size:14px;}
.vaygo-summary-row-qty-num{min-width:18px;text-align:center;font-size:14px;color:#111;}
.vaygo-summary-child-remove{color:#777;font-size:24px;}
.vaygo-summary-partial{display:flex;flex-direction:column;gap:12px;}
.vaygo-summary-single{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:22px;}
.vaygo-summary-single-left{display:flex;align-items:center;gap:14px;min-width:0;}
.vaygo-summary-single-img{width:46px;height:46px;object-fit:cover;border:1px solid #d9d9d9;border-radius:10px;background:#fff;flex:0 0 46px;}
.vaygo-summary-single-name{font-size:18px;line-height:1.35;color:#111;min-width:0;}
.vaygo-summary-totals{border-top:1px solid #e7e7e7;margin-top:18px;padding-top:12px;}
.vaygo-summary-total-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:4px 0;}
.vaygo-summary-total-row.is-subtotal .vaygo-summary-total-row-label{font-size:13px;color:#888;font-weight:400;}
.vaygo-summary-total-row.is-subtotal .vaygo-summary-total-row-value{font-size:13px;color:#888;font-weight:400;}
.vaygo-summary-total-row.is-final{padding-top:10px;border-top:1px solid #e7e7e7;margin-top:4px;}
.vaygo-summary-total-row-label{font-size:15px;color:#111;}
.vaygo-summary-total-row-value{font-size:16px;font-weight:700;color:#111;}
.vaygo-bundle-discount-row{margin-top:12px;display:flex;flex-direction:column;gap:6px;}
.vaygo-discount-line{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--vd-green);padding:4px 8px;background:rgba(22,163,74,.07);border-radius:6px;}
.vaygo-discount-value{font-weight:700;color:var(--vd-green);}
.vaygo-summary-total-row.is-discount .vaygo-summary-total-row-value{color:var(--vd-green);}
.vaygo-badge{font-size:11px;color:#888;margin-left:4px;}

/* ─── Qty / CTA ─── */
.vaygo-bottom-qty{display:inline-flex;align-items:center;justify-content:space-between;min-width:140px;padding:0 20px;border:0;border-right:2px solid #202020;border-radius:0;background:#fff;flex-shrink:0;}
.vaygo-bottom-qty-btn{appearance:none;-webkit-appearance:none;border:0;background:transparent;color:#111;font-size:inherit;line-height:1;cursor:pointer;padding:0;}
.vaygo-bottom-qty-num{min-width:22px;text-align:center;font-size:inherit;color:#111;}
.vaygo-cta{appearance:none;-webkit-appearance:none;cursor:pointer;padding:0 28px;border:0;font-size:22px;font-weight:700;transition:opacity .15s ease;}
.vaygo-cta:hover{opacity:.88;}

/* ═══════════════════════════════════════════════════════
   CUSTOM CART DRAWER
   ═══════════════════════════════════════════════════════ */
.vaygo-cart-overlay{position:fixed;inset:0;background:var(--vd-overlay);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:calc(var(--vd-z) - 1);}
.vaygo-cart-overlay.is-open{opacity:1;pointer-events:all;}

.vaygo-cart-drawer{position:fixed;top:0;right:0;height:100%;width:var(--vd-w);max-width:100vw;background:var(--vd-bg);box-shadow:-4px 0 32px rgba(0,0,0,.14);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);z-index:var(--vd-z);overflow:hidden;}
.vaygo-cart-drawer.is-open{transform:translateX(0);}
body.vaygo-drawer-open{overflow:hidden;}

/* Header */
.vaygo-cart-drawer-header{display:flex;align-items:center;gap:10px;padding:18px 20px 14px;border-bottom:1px solid #f0f0f0;flex-shrink:0;}
.vaygo-cart-drawer-title{font-size:17px;font-weight:700;color:#111;flex:1;}
.vaygo-cart-drawer-count{font-size:13px;color:#888;}
.vaygo-cart-drawer-close{appearance:none;-webkit-appearance:none;border:0;background:transparent;font-size:22px;line-height:1;cursor:pointer;color:#777;padding:4px;border-radius:6px;transition:background .15s;}
.vaygo-cart-drawer-close:hover{background:#f5f5f5;color:#111;}

/* Body */
.vaygo-cart-drawer-body{flex:1;overflow-y:auto;padding:12px 0;}
.vaygo-cart-drawer-body::-webkit-scrollbar{width:3px;}
.vaygo-cart-drawer-body::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:3px;}

/* Skeleton */
.vaygo-cart-skeleton{padding:0 16px;display:flex;flex-direction:column;gap:10px;}
.vaygo-cart-skeleton-item{height:76px;border-radius:10px;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%);background-size:200% 100%;animation:vaygo-shimmer 1.2s ease-in-out infinite;}
.vaygo-cart-skeleton-item.vaygo-skeleton-short{height:46px;width:70%;}

/* Empty */
.vaygo-cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60%;gap:12px;text-align:center;padding:24px;color:#888;}
.vaygo-cart-empty-icon{font-size:44px;line-height:1;}
.vaygo-cart-empty p{font-size:15px;margin:0;}
.vaygo-cart-continue{display:inline-block;margin-top:8px;padding:10px 22px;background:#111;color:#fff;text-decoration:none;border-radius:8px;font-size:13px;}

/* Bundle group */
.vaygo-cart-bundle-group{margin:0 12px 6px;border:1px solid #e8f5e9;border-radius:12px;background:#f9fff9;overflow:hidden;}
.vaygo-cart-bundle-badge{font-size:11px;font-weight:700;color:var(--vd-green);padding:5px 12px;background:rgba(22,163,74,.08);border-bottom:1px solid #e8f5e9;}

/* Cart item */
.vaygo-cart-item{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;transition:opacity .2s;}
.vaygo-cart-bundle-group .vaygo-cart-item{padding:10px 12px;}
.vaygo-cart-item+.vaygo-cart-item{border-top:1px solid #f5f5f5;}
.vaygo-cart-bundle-group .vaygo-cart-item+.vaygo-cart-item{border-top-color:#e8f5e9;}
.vaygo-cart-item.vaygo-cart-item-removing{opacity:.4;pointer-events:none;}
.vaygo-cart-item.vaygo-cart-item-mutating{opacity:.7;}

.vaygo-cart-item-img{width:58px;height:58px;object-fit:contain;border-radius:7px;border:1px solid #eee;background:#fafafa;flex-shrink:0;}
.vaygo-cart-item-img-ph{width:58px;height:58px;border-radius:7px;background:#f0f0f0;flex-shrink:0;}

.vaygo-cart-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:0px;}
/* Name + role badge on same line */
.vaygo-cart-item-name{display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:13px;}
.vaygo-cart-item-name a{font-weight:600;color:#111;text-decoration:none;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.vaygo-cart-item-name a:hover{text-decoration:underline;}
.vaygo-cart-role-badge{display:inline-block;font-size:10px;font-weight:700;padding:1px 5px;border-radius:4px;white-space:nowrap;line-height:1.4;}
.vaygo-role-core{background:#e8f0fe;color:#1743D7;}
.vaygo-role-wings{background:#fff3e5;color:#E47325;}

.vaygo-cart-item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
/* Fully rounded qty */
.vaygo-cart-item-qty-row{display:flex;align-items:center;gap:6px;border:1px solid #ddd;border-radius:999px;padding:2px 10px;}
.vaygo-cart-qty-btn{appearance:none;-webkit-appearance:none;border:0;background:transparent;color:#111;font-size:15px;cursor:pointer;padding:2px 0;line-height:1; min-height: 1px;}
.vaygo-cart-qty-val{min-width:18px;text-align:center;font-size:12px;font-weight:600;}
.vaygo-cart-item-price{display:flex;flex-direction:column;align-items:flex-end;gap:1px;margin-left:auto;}
.vaygo-cart-price-current{font-size:13px;font-weight:700;color:#111;white-space:nowrap;}
.vaygo-cart-price-old{font-size:11px;color:#aaa;text-decoration:line-through;white-space:nowrap;}
.vaygo-cart-item-remove{appearance:none;-webkit-appearance:none;border:0;background:transparent;color:#ccc;font-size:17px;cursor:pointer;padding:0;line-height:1;transition:color .15s;}
.vaygo-cart-item-remove:hover{color:#e53e3e;}

/* Footer */
.vaygo-cart-drawer-footer{border-top:1px solid #f0f0f0;padding:14px 18px;flex-shrink:0;display:flex;flex-direction:column;gap:7px;background:#fff;}
.vaygo-cart-totals{display:flex;flex-direction:column;gap:3px;margin-bottom:6px;}
.vaygo-cart-total-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#555;padding:2px 0;}
.vaygo-cart-total-row.is-discount{color:var(--vd-green);font-size:12px;}
.vaygo-cart-total-val{font-weight:600;}
.vaygo-discount-val{font-weight:700;}
.vaygo-cart-total-row.is-final{font-size:16px;font-weight:700;color:#111;border-top:1px solid #eee;padding-top:9px;margin-top:4px;}
/* Checkout button with theme blue */
.vaygo-cart-checkout-btn{display:block;text-align:center;background:var(--vd-blue);color:#fff;text-decoration:none;border-radius:10px;padding:13px;font-size:15px;font-weight:700;transition:opacity .15s;}
.vaygo-cart-checkout-btn:hover{opacity:.88;}
.vaygo-cart-view-link{display:block;text-align:center;font-size:12px;color:#888;text-decoration:underline;}

/* ─── Discount unlock animation ─── */
.vaygo-disc-label{display:inline-flex;align-items:center;gap:5px;}
.vaygo-disc-emoji{font-size:13px;line-height:1;flex-shrink:0;}
@keyframes vaygo-disc-pop{
  0%{transform:scale(1);}
  40%{transform:scale(1.06);}
  100%{transform:scale(1);}
}
.vaygo-disc-pop{animation:vaygo-disc-pop .45s ease-out;}
.vaygo-disc-row-bundle,.vaygo-disc-row-extra{
  border-radius:6px;
  transition:background .3s ease;
}
.vaygo-disc-pop.vaygo-disc-row-bundle,.vaygo-disc-pop.vaygo-disc-row-extra{
  background:rgba(217,240,85,.18);
}


/* ─── VAYGO Custom Lightbox ─── */
#vaygo-lb{display:none;position:fixed;inset:0;z-index:1000000;align-items:center;justify-content:center;}
#vaygo-lb.vlb-open{display:flex;}
.vlb-ov{position:absolute;inset:0;background:rgba(0,0,0,.9);}
.vlb-wrap{position:relative;max-width:90vw;max-height:90vh;z-index:1;display:flex;align-items:center;justify-content:center;}
.vlb-img{display:block;max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;}
.vlb-sh{position:absolute;inset:0;background:rgba(255,255,255,.07);animation:vaygo-shimmer 1.2s ease-in-out infinite;pointer-events:none;}
.vlb-x,.vlb-p,.vlb-n{position:fixed;z-index:2;appearance:none;border:0;background:rgba(255,255,255,.15);color:#fff;cursor:pointer;border-radius:50%;width:48px;height:48px;font-size:22px;display:flex;align-items:center;justify-content:center;transition:background .15s;padding:0;line-height:1;}
.vlb-x:hover,.vlb-p:hover,.vlb-n:hover{background:rgba(255,255,255,.28);}
.vlb-x{top:16px;right:16px;}
.vlb-p{left:16px;top:50%;transform:translateY(-50%);}
.vlb-n{right:16px;top:50%;transform:translateY(-50%);}
.vlb-ct{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;font-size:13px;background:rgba(0,0,0,.5);padding:4px 14px;border-radius:20px;pointer-events:none;}
@media(max-width:767px){.vlb-p{left:8px;}.vlb-n{right:8px;}.vlb-img{max-width:96vw;max-height:80vh;}}
.vaygo-cart-bundle-title-row{display:flex;align-items:center;gap:10px;margin:0;padding:8px 10px;background:#1743d7}
.vaygo-cart-bundle-thumb{width:36px;height:36px;object-fit:cover;border-radius:8px;flex:0 0 36px}
.vaygo-cart-bundle-thumb-ph{display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.18);color:#fff;font-size:16px;border-radius:8px}
.vaygo-cart-bundle-title{font-weight:600;font-size:11px;line-height:1.3;color:#fff}
.vaygo-cart-bundle-title a{color:#fff;text-decoration:none}
.vaygo-cart-bundle-title a:hover{text-decoration:underline;opacity:.88}

/* ═══════════════════════════════════════════════════
   VAYGO v3.7.9 additions
   ═══════════════════════════════════════════════════ */

/* ─── Add-to-cart button loading state ─── */
.vaygo-cta.is-adding {
  opacity: .72;
  cursor: not-allowed;
  pointer-events: none;
  position: relative;
  overflow: hidden;
}
.vaygo-cta.is-adding::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,.18) 50%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: vaygo-btn-shimmer .9s ease-in-out infinite;
}
@keyframes vaygo-btn-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.vaygo-cta:disabled { cursor: not-allowed; }

/* ─── Cart drawer "Updating…" bar ─── */
.vaygo-cart-updating-bar {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  color: rgba(255,255,255,.72);
  padding: 7px 16px 4px;
  letter-spacing: .02em;
}
.vaygo-updating-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #D9F055;
  animation: vaygo-dot-pulse 1s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes vaygo-dot-pulse {
  0%,100% { opacity: 1;   transform: scale(1);    }
  50%      { opacity: .45; transform: scale(.65);  }
}

/* ─── SSR title slot: prevent layout shift while React hydrates ─── */
[data-vaygo-slot="title"][data-vaygo-ssr="1"] {
  /* Slot already has content from PHP — no min-height placeholder needed */
  min-height: 0;
}
/* Hide the SSR span after React has taken over (optional — hydration keeps it) */
[data-vaygo-slot="title"] span {
  display: block;
}

/* ═══════════════════════════════════════════════════
   VAYGO v3.8.0 — SSR slots, add-to-cart toast, wishlist
   ═══════════════════════════════════════════════════ */

/* ─── SSR slots: all pre-rendered slots ─── */
[data-vaygo-ssr="1"] {
  min-height: 0;
}
/* Gallery SSR: pre-rendered image fills the slot correctly before React mounts */
[data-vaygo-slot="gallery"][data-vaygo-ssr="1"] .vaygo-gallery {
  width: 100%;
}
[data-vaygo-slot="gallery"][data-vaygo-ssr="1"] .vaygo-gallery-main-wrap {
  width: 100%;
  position: relative;
  overflow: hidden;
}
[data-vaygo-slot="gallery"][data-vaygo-ssr="1"] .vaygo-gallery-main {
  width: 100%;
  height: var(--vaygo-gallery-main-height, 400px);
  object-fit: contain;
  display: block;
}
/* Remove any shimmer from gallery (no loading indicator) */
.vaygo-gallery-loading-shimmer { display: none !important; }
.vaygo-gallery-main-wrap.is-loading { opacity: 1 !important; }

/* ─── Add-to-cart inline toast ─── */
.vaygo-atc-toast {
  display: flex;
  align-items: center;
  gap: 9px;
  background: #fff;
  border: 1px solid #ebebeb;
  border-radius: 12px;
  padding: 11px 18px;
  margin-top: 12px;
  font-size: 14px;
  color: #333;
  font-weight: 500;
  box-shadow: 0 4px 16px rgba(0,0,0,.07);
  animation: vaygo-toast-in .22s cubic-bezier(.22,1,.36,1);
}
.vaygo-atc-toast-dot {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #e47325;
  animation: vaygo-dot-pulse 1s ease-in-out infinite;
}
@keyframes vaygo-toast-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0);   }
}

/* ═══════════════════════════════════════════════════
   VAYGO Native Wishlist
   ═══════════════════════════════════════════════════ */

/* ─── Heart button ─── */
#vaygo-wishlist-root *{
	font-family: var(--e-global-typography-e0e8ee1-font-family), Sans-serif;
}
.vaygo-wl-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  padding: 6px;
  cursor: pointer;
  border-radius: 50%;
  transition: background .15s, transform .1s;
  color: #111;
  line-height: 1;
  padding: 0 !important;
  min-height: 0 !important;
  line-height: 1;
  position: relative;
}
.vaygo-wl-btn:hover  { background: rgba(0,0,0,.06); }
.vaygo-wl-btn:active { transform: scale(.9); }
.vaygo-wl-btn.vaygo-wl-busy { opacity: .55; pointer-events: none; }
/* Heart SVG */
.vaygo-wl-heart {
  width: 22px;
  height: 22px;
  display: block;
  transition: transform .18s cubic-bezier(.34,1.56,.64,1), opacity .15s;
}
/* Loading pulse during AJAX */
.vaygo-wl-busy .vaygo-wl-heart {
  animation: vaygo-wl-pulse .7s ease-in-out infinite;
}
@keyframes vaygo-wl-pulse {
  0%,100% { opacity: 1;   transform: scale(1);    }
  50%      { opacity: .45; transform: scale(.8);   }
}
/* Active / filled state */
.vaygo-wl-btn.is-active .vaygo-wl-heart,
.vaygo-wl-heart.is-filled { color: #e47325; }

/* ─── Counter badge ─── */
.vaygo-wl-count {
  position: absolute;
    top: 0;
    right: 0;
    transform: translate(60%, -40%);
    color: white;
    background: #e47325;
    width: 16px;
    height: 16px;
    font-size: 10px;
    display: flex;
    text-align: center;
    border-radius: 100%;
    align-items: center;
    justify-content: center;
    font-weight: 600;
}
.vaygo-wl-counter .vaygo-wl-heart {
  display: block;
    width: 100%;
    height: 25px;
    max-width: 100%;
    max-height: 100%;
    margin: -2px 0 0px 0;
    object-fit: contain;
    color: #444;
}

/* ─── Wishlist page ─── */
.vaygo-wl-page {
  width: 100%;
}
.vaygo-wl-items {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Individual item row — mirrors vaygo-summary-child style */
.vaygo-wl-item {
  display: flex;
  align-items: center;
  gap: 14px;
  background: #fff;
  border: 1px solid #ebebeb;
  border-radius: 12px;
  padding: 14px 16px;
  transition: opacity .3s, transform .3s;
}
.vaygo-wl-item-removing {
  opacity: 0;
  transform: translateX(16px);
  pointer-events: none;
}

/* Product thumbnail */
.vaygo-wl-item-img {
  width: 68px;
  height: 68px;
  object-fit: cover;
  border-radius: 8px;
  flex-shrink: 0;
  background: #f5f5f5;
  display: block;
}
.vaygo-wl-item-img-ph {
  background: #f0f0f0;
}

/* Text body */
.vaygo-wl-item-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.vaygo-wl-item-name {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}
.vaygo-wl-item-name a {
  font-weight: 600;
  font-size: 14px;
  color: #111;
  text-decoration: none;
  line-height: 1.4;
}
.vaygo-wl-item-name a:hover { text-decoration: underline; }
.vaygo-wl-item-price {
  font-size: 14px;
  color: #333;
}
.vaygo-wl-item-price .woocommerce-Price-amount { font-weight: 600; }

/* Role badge */
.vaygo-wl-role-badge {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 2px 7px;
  border-radius: 999px;
  background: #f0f0f0;
  color: #555;
  white-space: nowrap;
}
.vaygo-wl-role-core  { background: #e8f0fb; color: #1743d7; }
.vaygo-wl-role-wings { background: #fef3e8; color: #e47325; }
.vaygo-wl-role-tote  { background: #111;    color: #fff;    }

/* Action buttons on right */
.vaygo-wl-item-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}
/* Add to Cart — inherits .vaygo-cta styles */
.vaygo-wl-atc-btn {
  font-size: 13px;
  padding: 8px 18px;
  white-space: nowrap;
}
.vaygo-wl-atc-btn.vaygo-wl-busy {
  opacity: .6;
  pointer-events: none;
}
/* Remove button */
.vaygo-wl-remove-btn {
  background: none;
  border: none;
  font-size: 20px;
  line-height: 1;
  color: #aaa;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 4px;
  transition: color .15s, background .15s;
}
.vaygo-wl-remove-btn:hover { color: #e00; background: rgba(220,0,0,.07); }
.vaygo-wl-remove-btn.vaygo-wl-busy { opacity: .4; pointer-events: none; }
/* Out of stock */
.vaygo-wl-oos {
  font-size: 12px;
  color: #999;
  font-style: italic;
}

/* ─── Empty state ─── */
.vaygo-wl-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 64px 24px;
  text-align: center;
}
.vaygo-wl-empty .vaygo-wl-heart {
  width: 52px;
  height: 52px;
  color: #ccc;
}
.vaygo-wl-empty-msg {
  font-size: 18px;
  color: #555;
  margin: 0;
}
.vaygo-wl-continue {
  display: inline-block;
  padding: 10px 28px;
  background: #111;
  color: #fff;
  border-radius: 999px;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  transition: opacity .15s;
}
.vaygo-wl-continue:hover { opacity: .82; }

/* ─── Responsive ─── */
@media (max-width: 540px) {
  .vaygo-wl-item {
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px 12px;
  }
  .vaygo-wl-item-actions {
    flex-direction: row;
    align-items: center;
    width: 100%;
    justify-content: flex-end;
  }
  .vaygo-wl-item-img { width: 54px; height: 54px; }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
.vaygo-wl-unit .vaygo-actions {
    max-width: 30%;
}
}

@media (max-width: 768px) {
.vaygo-wl-unit .vaygo-actions {
    max-width: 100%;
}
.vaygo-wl-unit.vaygo-wl-unit-compact {
    flex-direction: column;
}}

/* ═══════════════════════════════════════════════════
   Cart drawer — header adding-to-cart status
   ═══════════════════════════════════════════════════ */

.vaygo-cart-drawer-header {
  display: flex;
  align-items: center;
  gap: 10px;
}
.vaygo-cart-header-left {
  display: flex;
  align-items: center;
  gap: 9px;
  flex: 1;
  min-width: 0;
}
.vaygo-cart-header-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: rgba(255,255,255,.72);
  letter-spacing: .02em;
  white-space: nowrap;
  /* Animate in when content appears */
  animation: vaygo-status-in .18s ease;
}
.vaygo-cart-header-status:empty {
  display: none;
}
@keyframes vaygo-status-in {
  from { opacity: 0; transform: translateX(-4px); }
  to   { opacity: 1; transform: translateX(0);    }
}
/* The pulsing dot reuses the existing vaygo-updating-dot keyframe */
.vaygo-cart-header-status .vaygo-updating-dot {
  width: 7px;
  height: 7px;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════
   Wishlist page — product unit (vaygo-wl-unit)
   Uses .vaygo-summary-box + .vaygo-actions exactly
   as the PDP does — no new component CSS needed.
   ═══════════════════════════════════════════════════ */

.vaygo-wl-units {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.vaygo-wl-unit {
  background: #fff;
  border: 1px solid #ebebeb;
  border-radius: 16px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: box-shadow .2s;
}
.vaygo-wl-unit.vaygo-wl-unit-compact{
	flex-direction: row;
}
.vaygo-wl-unit:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.07);
}
.vaygo-wl-unit-loading {
  gap: 12px;
  min-height: 120px;
}

/* Product header: image + name/price row + remove button */
.vaygo-wl-unit-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
	width: 100%;
}
.vaygo-wl-unit .vaygo-action-row button{
	width: 100%;
}
.vaygo-wl-unit .vaygo-actions {
	max-width:20%;
}
.vaygo-wl-unit-img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 10px;
  flex-shrink: 0;
  display: block;
  background: #f5f5f5;
}
.vaygo-wl-item-img-ph {
  background: #f0f0f0;
}
.vaygo-wl-unit-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.vaygo-wl-unit-name {
  font-weight: 700;
  font-size: 15px;
  color: #111;
  text-decoration: none;
  line-height: 1.35;
  display: block;
}
.vaygo-wl-unit-name:hover { text-decoration: underline; }
.vaygo-wl-unit-price .woocommerce-Price-amount { font-weight: 600; font-size: 14px; }
.vaygo-wl-unit-price ins { text-decoration: none; }

/* Remove (×) button */
.vaygo-wl-remove-btn {
  background: none;
  border: none;
  font-size: 22px;
  line-height: 1;
  color: #bbb;
  cursor: pointer;
  padding: 0 4px;
  border-radius: 4px;
  flex-shrink: 0;
  transition: color .15s, background .15s;
  margin-left: auto;
  order: -1;
}
.vaygo-wl-remove-btn:hover { color: #e00; background: rgba(220,0,0,.07); }
.vaygo-wl-remove-btn.vaygo-wl-busy { opacity: .4; pointer-events: none; }

/* CYOB hint */
.vaygo-wl-unit-cyob-hint {
  font-size: 13px;
  color: #666;
  margin: 0;
}
.vaygo-wl-unit-cyob-hint a { color: inherit; font-weight: 600; }

/* Error */
.vaygo-wl-unit-error {
  font-size: 13px;
  color: #c00;
  margin: 0;
}

/* Responsive */
@media (max-width: 480px) {
  .vaygo-wl-unit { padding: 14px; gap: 12px; }
  .vaygo-wl-unit-img { width: 60px; height: 60px; }
  .vaygo-wl-unit-name { font-size: 14px; }
}
