/* ═══════════════════════════════════════════════════════
   PERFECTO QUICK VIEW — VIBE THEME
   Matches reference: minimal, clean, Elessi-style
   ═══════════════════════════════════════════════════════ */

/* Loading spinner */
.pf-qv-loading-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99999;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .22s;pointer-events:none}
.pf-qv-loading-overlay.is-visible{opacity:1;pointer-events:auto}
.pf-qv-spinner{display:flex;gap:8px}
.pf-qv-spinner>div{width:10px;height:10px;border-radius:50%;background:#fff;animation:pfQvB 1.2s infinite ease-in-out}
.pf-qv-spinner>div:nth-child(2){animation-delay:.16s}
.pf-qv-spinner>div:nth-child(3){animation-delay:.32s}
@keyframes pfQvB{0%,80%,100%{transform:scale(0);opacity:.4}40%{transform:scale(1);opacity:1}}
body.pf-qv-open{overflow:hidden!important}

/* Modal */
#pf-qv-modal{position:fixed;inset:0;z-index:99998;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease}
#pf-qv-modal.is-active{opacity:1;pointer-events:auto}
#pf-qv-modal .pf-qv-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5)}

/* Panel — clean white card matching reference */
#pf-qv-modal .pf-qv-panel{position:relative;background:#fff;border-radius:16px;width:min(92vw,900px);height:min(80vh,700px);overflow:hidden;display:flex;flex-direction:column;z-index:1;transform:translateY(16px) scale(.978);transition:transform .3s cubic-bezier(.16,1,.3,1);box-shadow:0 20px 60px rgba(0,0,0,.18),0 4px 16px rgba(0,0,0,.08)}
#pf-qv-modal.is-active .pf-qv-panel{transform:none}
#pf-qv-modal .pf-qv-panel.is-closing{transform:translateY(100%)!important;transition:transform .26s ease!important}

/* Close — top right, minimal */
#pf-qv-modal .pf-qv-close{position:absolute;top:14px;right:14px;z-index:30;width:32px;height:32px;border-radius:50%;background:#f5f5f5;border:1px solid #e8e8e8;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .2s}
#pf-qv-modal .pf-qv-close svg{stroke:#333;width:16px;height:16px}
#pf-qv-modal .pf-qv-close:hover{background:#111;transform:rotate(90deg)}
#pf-qv-modal .pf-qv-close:hover svg{stroke:#fff}

/* Inner grid — 55% image / 45% summary */
#pf-qv-modal .pf-qv-inner{display:grid;grid-template-columns:1.2fr 1fr;flex:1;min-height:0;overflow:hidden;align-items:stretch}

/* Gallery — light grey bg, full bleed */
#pf-qv-modal .pf-qv-gallery-col{background:#f7f7f7;border-radius:16px 0 0 16px;overflow:hidden;display:flex;flex-direction:column}
#pf-qv-modal .pf-qv-track-wrap{position:relative;flex:1;overflow:hidden}
#pf-qv-modal .pf-qv-track{display:flex;width:100%;height:100%;transition:transform .35s cubic-bezier(.25,.8,.25,1);will-change:transform}
#pf-qv-modal .pf-qv-slide{min-width:100%;width:100%;height:100%;flex-shrink:0;overflow:hidden;position:relative}
#pf-qv-modal .pf-qv-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block}
#pf-qv-modal .pf-qv-slide video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* Sale badge */
#pf-qv-modal .pf-qv-badge{position:absolute;top:12px;left:12px;z-index:10;background:#333;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;pointer-events:none;letter-spacing:.3px}

/* Nav arrows — minimal circles */
#pf-qv-modal .pf-qv-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:34px;height:34px;border-radius:50%;background:#fff;border:1px solid #e5e5e5;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.08);transition:all .18s}
#pf-qv-modal .pf-qv-nav svg{stroke:#333;width:14px;height:14px}
#pf-qv-modal .pf-qv-nav-prev{left:12px}
#pf-qv-modal .pf-qv-nav-next{right:12px}
#pf-qv-modal .pf-qv-nav:hover{background:#fff;box-shadow:0 4px 14px rgba(0,0,0,.14);transform:translateY(-50%) scale(1.05)}

/* Dots */
#pf-qv-modal .pf-qv-dots{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:5px;align-items:center}
#pf-qv-modal .pf-qv-dot{width:6px;height:6px;border-radius:50%;background:rgba(0,0,0,.2);border:none;padding:0;cursor:pointer;transition:all .2s}
#pf-qv-modal .pf-qv-dot.is-active{background:#333;width:16px;border-radius:3px}

/* View full btn — below image */
#pf-qv-modal .pf-qv-fulllink{display:flex;align-items:center;justify-content:center;padding:11px 0;background:#fff;color:#555;font-size:11px;font-weight:600;letter-spacing:.8px;text-decoration:none;text-transform:uppercase;border-top:1px solid #efefef;flex-shrink:0;transition:color .18s}
#pf-qv-modal .pf-qv-fulllink:hover{color:#111}
#pf-qv-modal .pf-qv-fulllink-mobile{display:none}

/* ═══════════════════════════════════════════
   SUMMARY — reference-style: stars+brand top,
   big title, clean price, desc with read more,
   native WC ATC below
   ═══════════════════════════════════════════ */
#pf-qv-modal .pf-qv-summary{padding:28px 28px 24px 26px;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:14px;scrollbar-width:thin;scrollbar-color:#e8e8e8 transparent}
#pf-qv-modal .pf-qv-summary::-webkit-scrollbar{width:3px}
#pf-qv-modal .pf-qv-summary::-webkit-scrollbar-thumb{background:#e5e5e5;border-radius:2px}

/* Stars + brand row */
#pf-qv-modal .pf-qv-top-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
#pf-qv-modal .pf-qv-stars{display:flex;align-items:center;gap:2px}
#pf-qv-modal .pf-qv-rcount{font-size:12px;color:#888;text-decoration:none;margin-left:4px}
#pf-qv-modal .pf-qv-rcount:hover{color:#333}
#pf-qv-modal .pf-qv-brand{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid #e5e5e5;border-radius:6px;font-size:11px;font-weight:600;color:#333;letter-spacing:.3px}

/* Title — large, clean */
#pf-qv-modal .pf-qv-title{font-size:22px;font-weight:700;line-height:1.25;color:#111;margin:0}
#pf-qv-modal .pf-qv-title a{color:inherit;text-decoration:none}
#pf-qv-modal .pf-qv-title a:hover{color:#555}

/* Price */
#pf-qv-modal .pf-qv-price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
#pf-qv-modal .pf-qv-price .price{font-size:22px;font-weight:700;color:#111;display:flex;align-items:baseline;gap:8px}
#pf-qv-modal .pf-qv-price .price ins{text-decoration:none}
#pf-qv-modal .pf-qv-price .price ins .woocommerce-Price-amount,
#pf-qv-modal .pf-qv-price .price ins .amount{font-size:22px;font-weight:700;color:#111}
#pf-qv-modal .pf-qv-price .price del .woocommerce-Price-amount,
#pf-qv-modal .pf-qv-price .price del .amount{font-size:15px;color:#aaa;text-decoration:line-through}
#pf-qv-modal .pf-qv-price .price>.woocommerce-Price-amount.amount{font-size:22px;font-weight:700;color:#111}
#pf-qv-modal .pf-qv-save{font-size:11px;font-weight:600;color:#555;background:#f5f5f5;padding:3px 9px;border-radius:4px}

/* Short description — clamped with read more */
#pf-qv-modal .pf-qv-desc-wrap{display:flex;flex-direction:column;gap:6px;border-bottom:1px solid #f0f0f0;padding-bottom:4px}
#pf-qv-modal .pf-qv-desc{font-size:13.5px;line-height:1.65;color:#555;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
#pf-qv-modal .pf-qv-desc.is-expanded{display:block;-webkit-line-clamp:unset}
#pf-qv-modal .pf-qv-readmore{display:inline-flex;align-items:center;gap:4px;background:none;border:none;font-size:12.5px;font-weight:600;color:#333;cursor:pointer;padding:0;transition:color .15s}
#pf-qv-modal .pf-qv-readmore:hover{color:#000}

/* ATC — override WC defaults */
#pf-qv-modal .pf-qv-atc-wrap{display:flex;flex-direction:column;gap:0}
#pf-qv-modal .pf-qv-atc-wrap form.cart{display:flex!important;flex-direction:column!important;gap:10px!important;margin:0!important}
#pf-qv-modal .pf-qv-atc-wrap .variations{margin:0!important}
#pf-qv-modal .pf-qv-atc-wrap .variations tr{display:flex!important;flex-direction:column!important;gap:6px!important;margin-bottom:10px!important}
#pf-qv-modal .pf-qv-atc-wrap .variations td,
#pf-qv-modal .pf-qv-atc-wrap .variations th{padding:0!important;border:none!important}
#pf-qv-modal .pf-qv-atc-wrap .variations label{font-size:11px!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.6px!important;color:#333!important;margin:0 0 4px!important;display:block!important}

/* Qty + ATC row */
#pf-qv-modal .pf-qv-atc-wrap .quantity{display:inline-flex!important;align-items:stretch!important;border:1.5px solid #ddd!important;border-radius:8px!important;overflow:hidden!important;height:44px!important;background:#fff!important}
#pf-qv-modal .pf-qv-atc-wrap .quantity .qty-btn,
#pf-qv-modal .pf-qv-atc-wrap .quantity button{width:36px!important;background:#f8f8f8!important;border:none!important;font-size:16px!important;cursor:pointer!important;color:#111!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important}
#pf-qv-modal .pf-qv-atc-wrap .quantity input.qty{width:44px!important;text-align:center!important;border:none!important;border-left:1.5px solid #ddd!important;border-right:1.5px solid #ddd!important;font-size:14px!important;font-weight:600!important;background:#fff!important;-moz-appearance:textfield!important}
#pf-qv-modal .pf-qv-atc-wrap .quantity input.qty::-webkit-inner-spin-button,
#pf-qv-modal .pf-qv-atc-wrap .quantity input.qty::-webkit-outer-spin-button{-webkit-appearance:none!important}

#pf-qv-modal .pf-qv-atc-wrap .pf-atc-row{display:flex!important;align-items:stretch!important;gap:8px!important}

/* ADD TO CART — salmon/coral like reference */
#pf-qv-modal .pf-qv-atc-wrap .single_add_to_cart_button,
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-atc{flex:1!important;height:44px!important;background:#e8705a!important;color:#fff!important;border:none!important;border-radius:8px!important;font-size:11px!important;font-weight:700!important;letter-spacing:.8px!important;cursor:pointer!important;text-transform:uppercase!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:background .18s!important}
#pf-qv-modal .pf-qv-atc-wrap .single_add_to_cart_button:hover,
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-atc:hover{background:#d45f49!important}

/* BUY NOW — green like reference */
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-buynow,
#pf-qv-modal .pf-qv-atc-wrap .pf-buy-now{width:100%!important;height:44px!important;background:#5b9a4e!important;color:#fff!important;border:none!important;border-radius:8px!important;font-size:11px!important;font-weight:700!important;letter-spacing:.8px!important;text-transform:uppercase!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:background .18s!important}
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-buynow:hover,
#pf-qv-modal .pf-qv-atc-wrap .pf-buy-now:hover{background:#4a8340!important}

/* Wishlist */
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-wishlist{width:44px!important;height:44px!important;flex-shrink:0!important;background:#fff!important;border:1.5px solid #ddd!important;border-radius:8px!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;transition:border-color .18s!important}
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-wishlist svg{stroke:#999!important;fill:none!important;width:16px!important;height:16px!important}
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-wishlist:hover{border-color:#e8705a!important}
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-wishlist:hover svg{stroke:#e8705a!important}
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-wishlist.in-wishlist svg,
#pf-qv-modal .pf-qv-atc-wrap .pf-btn-wishlist.active svg{fill:#e8705a!important;stroke:#e8705a!important}

/* Action buttons */
#pf-qv-modal .pf-qv-actions{display:flex;gap:6px;flex-wrap:wrap}
#pf-qv-modal .pf-qv-action-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border:1px solid #e5e5e5;border-radius:20px;background:#fafafa;font-size:11px;font-weight:600;color:#555;cursor:pointer;text-decoration:none;transition:all .15s}
#pf-qv-modal .pf-qv-action-btn:hover{background:#f0f0f0;color:#111;border-color:#ccc}

/* Taxonomy */
#pf-qv-modal .pf-qv-tax{font-size:11.5px;color:#999;margin-top:2px}
#pf-qv-modal .pf-qv-tax strong{color:#555}

/* Swatch states */
#pf-qv-modal .pf-color-swatch.unavailable,
#pf-qv-modal .pf-size-btn.unavailable,
#pf-qv-modal .pf-attribute-btn.unavailable{opacity:.35;cursor:not-allowed}

/* ═══ MOBILE ≤767px ═══ */
@media(max-width:767px){
  #pf-qv-modal{align-items:flex-end}
  #pf-qv-modal .pf-qv-panel{width:100%;max-width:100%;height:auto!important;max-height:92vh!important;border-radius:20px 20px 0 0;transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1)}
  #pf-qv-modal.is-active .pf-qv-panel{transform:translateY(0)}
  #pf-qv-modal .pf-qv-panel::before{content:'';display:block;width:36px;height:4px;background:#ddd;border-radius:2px;margin:12px auto 4px;flex-shrink:0}
  #pf-qv-modal .pf-qv-inner{grid-template-columns:1fr;overflow-y:auto;flex:1;min-height:0;display:flex;flex-direction:column}
  #pf-qv-modal .pf-qv-gallery-col{border-radius:0;height:55vw;max-height:55vh;flex-shrink:0}
  #pf-qv-modal .pf-qv-slide img{object-fit:cover!important}
  #pf-qv-modal .pf-qv-nav{background:rgba(255,255,255,.2)!important;border-color:rgba(255,255,255,.3)!important}
  #pf-qv-modal .pf-qv-nav svg{stroke:#fff}
  #pf-qv-modal .pf-qv-dot{background:rgba(255,255,255,.4)}
  #pf-qv-modal .pf-qv-dot.is-active{background:#fff}
  #pf-qv-modal .pf-qv-close{background:rgba(0,0,0,.25)!important;border-color:transparent!important}
  #pf-qv-modal .pf-qv-close svg{stroke:#fff!important}
  #pf-qv-modal .pf-qv-fulllink{display:none!important}
  #pf-qv-modal .pf-qv-fulllink-mobile{display:flex!important;align-items:center;justify-content:center;position:sticky;bottom:0;width:100%;padding:13px;background:#f7f7f7;color:#333;font-size:11px;font-weight:700;letter-spacing:.8px;text-decoration:none;text-transform:uppercase;border-top:1px solid #efefef;z-index:20;flex-shrink:0}
  #pf-qv-modal .pf-qv-summary{padding:16px 18px 16px!important;gap:10px!important}
  #pf-qv-modal .pf-qv-title{font-size:17px}
}
