/* ==========================================================================
   PDP Component Styles
   Consolidated from inline <style> blocks in template-parts/components/
   Loaded conditionally on single product pages via enqueue.php
   ========================================================================== */

/* --- Product Bundles / Upsell Mini --- */
.upsell-mini{margin:16px 0;padding:12px 16px;background:#f9f9f9;border:1px solid #e5e5e5;border-radius:8px}
.upsell-mini__checkbox{display:flex;align-items:center;gap:12px;cursor:pointer;user-select:none}
.upsell-mini__input{position:absolute;opacity:0;width:0;height:0}
.upsell-mini__checkmark{flex-shrink:0;width:22px;height:22px;border:2px solid #ccc;border-radius:4px;background:#fff;display:flex;align-items:center;justify-content:center;transition:background .15s ease,border-color .15s ease}
.upsell-mini__input:checked+.upsell-mini__checkmark{background:var(--wvh-orange,#FF7900);border-color:var(--wvh-orange,#FF7900)}
.upsell-mini__input:checked+.upsell-mini__checkmark::after{content:'';width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}
.upsell-mini__content{display:flex;align-items:center;gap:12px;flex:1}
.upsell-mini__content img.upsell-mini__image{width:48px;height:48px;object-fit:cover;border-radius:6px;border:1px solid #eee}
.upsell-mini__info{display:flex;flex-direction:column;gap:2px}
.upsell-mini__text{font-size:14px;color:#333;line-height:1.3}
.upsell-mini__text strong{color:#111}
.upsell-mini__price{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#333}
.upsell-mini__price .woocommerce-Price-amount{color:#333}
.upsell-mini__discount{font-size:11px;font-weight:600;color:#15803d;background:#dcfce7;padding:2px 6px;border-radius:4px}
.upsell-mini__checkbox:hover .upsell-mini__checkmark{border-color:var(--wvh-orange,#FF7900)}
.upsell-mini:has(.upsell-mini__input:checked){background:#fff7ed;border-color:var(--wvh-orange,#FF7900)}
@media(max-width:480px){.upsell-mini{padding:10px 12px}.upsell-mini__content img.upsell-mini__image{width:40px;height:40px}.upsell-mini__text{font-size:13px}.upsell-mini__price{font-size:13px;flex-wrap:wrap;gap:4px}}

/* --- Product Specs --- */
.product-specs{background:white;border-radius:16px;padding:32px;margin:32px 0;box-shadow:0 1px 3px rgba(0,0,0,0.03),0 4px 16px rgba(0,0,0,0.03)}
.product-specs__title{display:flex;align-items:center;gap:12px;font-family:'Bebas Neue',Impact,sans-serif;font-size:26px;color:#111;margin:0 0 24px;letter-spacing:.5px}
.product-specs__title-icon{width:44px;height:44px;background:var(--wvh-orange-light,#FFF4EB);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--wvh-orange,#FF7900)}
.product-specs__table{display:flex;flex-direction:column;gap:0}
.product-specs__row{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:14px 0;border-bottom:1px solid #f0f0f0}
.product-specs__row:last-child{border-bottom:none}
.product-specs__label{display:flex;align-items:center;gap:12px;font-size:14px;color:#666}
.product-specs__icon{width:32px;height:32px;background:#f5f5f5;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#888;flex-shrink:0}
.product-specs__value{font-size:14px;font-weight:600;color:#111;display:flex;align-items:center}
@media(max-width:600px){.product-specs{padding:24px 20px}.product-specs__title{font-size:22px}.product-specs__row{grid-template-columns:1fr;gap:6px;padding:12px 0}.product-specs__value{padding-left:44px}}

/* --- Product Description --- */
.product-description{background:white;border-radius:16px;padding:32px;margin:32px 0;box-shadow:0 1px 3px rgba(0,0,0,0.03),0 4px 16px rgba(0,0,0,0.03)}
.product-description__heading{display:flex;align-items:center;gap:12px;font-family:'Bebas Neue',Impact,sans-serif;font-size:26px;color:#111;margin:0 0 20px;letter-spacing:.5px}
.product-description__heading-icon{width:44px;height:44px;background:var(--wvh-orange-light,#FFF4EB);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--wvh-orange,#FF7900)}
.product-description__intro{font-size:16px;line-height:1.7;color:#444;margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid #eee}
.product-description__intro p{margin:0}
.product-description__subheading{font-size:18px;font-weight:700;color:#111;margin:0 0 16px}
.product-description__benefits-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.product-description__benefits-list li{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#f8f8f8;border-radius:10px;font-size:14px;color:#444;line-height:1.5}
.product-description__benefit-icon{flex-shrink:0;width:24px;height:24px;color:#22c55e}
.product-description__benefits-list strong{color:#111}
.product-description__full{margin-top:28px;padding-top:28px;border-top:1px solid #eee}
.product-description__details{background:#f8f8f8;border-radius:12px}
.product-description__summary{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;font-size:15px;font-weight:600;color:#111;list-style:none}
.product-description__summary::-webkit-details-marker{display:none}
.product-description__summary svg{transition:transform .3s ease;color:#666}
.product-description__details[open] .product-description__summary svg{transform:rotate(180deg)}
.product-description__content{padding:0 20px 20px;font-size:15px;line-height:1.7;color:#444}
.product-description__content p{margin:0 0 12px}
.product-description__content p:last-child{margin-bottom:0}
@media(max-width:768px){.product-description{padding:24px 20px}.product-description__heading{font-size:22px}.product-description__benefits-list{grid-template-columns:1fr}.product-description__benefits-list li{padding:12px 14px}}

/* --- Product Reviews --- */
.product-reviews{background:white;border-radius:16px;padding:32px;margin:32px 0;box-shadow:0 1px 3px rgba(0,0,0,0.03),0 4px 16px rgba(0,0,0,0.03)}
.product-reviews__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #eee}
.product-reviews__title{display:flex;align-items:center;gap:10px;font-family:'Bebas Neue',Impact,sans-serif;font-size:26px;color:#111;margin:0;letter-spacing:.5px}
.product-reviews__title-icon{font-size:28px}
.product-reviews__summary{display:flex;align-items:center;gap:12px}
.product-reviews__score{display:flex;align-items:baseline}
.product-reviews__score-number{font-size:32px;font-weight:800;color:#111}
.product-reviews__score-max{font-size:16px;color:#666}
.product-reviews__stars{display:flex;gap:2px}
.product-reviews__stars .star{font-size:18px}
.product-reviews__stars .star--filled{color:#F59E0B}
.product-reviews__stars .star--empty{color:#ddd}
.product-reviews__count{font-size:14px;color:#666}
.product-reviews__list{display:flex;flex-direction:column;gap:20px}
.product-reviews__item{padding:20px;background:#f9f9f9;border-radius:12px}
.product-reviews__item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.product-reviews__item-author{display:flex;align-items:center;gap:12px}
.product-reviews__avatar{width:40px;height:40px;background:var(--wvh-orange,#FF7900);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}
.product-reviews__item-author strong{font-size:15px;color:#111}
.product-reviews__role{font-size:13px;color:#666;font-weight:400}
.product-reviews__verified{display:flex;align-items:center;gap:4px;font-size:12px;color:#22c55e;font-weight:500}
.product-reviews__item-rating{display:flex;gap:2px}
.product-reviews__item-rating .star{font-size:14px}
.product-reviews__item-rating .star--filled{color:#F59E0B}
.product-reviews__item-rating .star--empty{color:#ddd}
.product-reviews__item-text{font-size:15px;line-height:1.6;color:#444;margin:0 0 10px;font-style:italic}
.product-reviews__item-date{font-size:12px;color:#999}
.product-reviews__cta{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:24px;padding-top:24px;border-top:1px solid #eee}
.product-reviews__cta p{font-size:14px;color:#666;margin:0}
.product-reviews__write-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:#111;color:white;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s ease,transform .2s ease}
.product-reviews__write-btn:hover{background:var(--wvh-orange,#FF7900);transform:translateY(-2px);color:white}
@media(max-width:768px){.product-reviews{padding:24px 20px}.product-reviews__header{flex-direction:column;align-items:flex-start}.product-reviews__title{font-size:22px}.product-reviews__item-header{flex-direction:column;gap:8px}.product-reviews__cta{flex-direction:column;align-items:flex-start;gap:12px}.product-reviews__write-btn{width:100%;justify-content:center}}

/* --- Maathulp Mini --- */
.maathulp-mini{background:#FFF8F0;border:1px solid #FFD9B3;border-radius:14px;padding:20px 24px;margin:24px 0}
.maathulp-mini__header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.maathulp-mini__icon{font-size:22px}
.maathulp-mini__title{font-size:17px;font-weight:700;color:#111;margin:0}
.maathulp-mini__tips{list-style:none;padding:0;margin:0 0 16px}
.maathulp-mini__tips li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;font-size:14px;color:#444;border-bottom:1px solid rgba(255,200,150,.3)}
.maathulp-mini__tips li:last-child{border-bottom:none}
.maathulp-mini__bullet{color:var(--wvh-orange,#FF7900);font-weight:700;flex-shrink:0}
.maathulp-mini__tips strong{color:var(--wvh-orange,#FF7900);font-weight:700}
.maathulp-mini__cta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding-top:4px}
.maathulp-mini__cta-text{font-size:13px;color:#666}
.maathulp-mini__whatsapp{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#25D366;color:white;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;transition:background .2s ease,transform .2s ease}
.maathulp-mini__whatsapp:hover{background:#128C7E;transform:translateY(-1px);color:white}
@media(max-width:600px){.maathulp-mini{padding:16px 18px}.maathulp-mini__cta{flex-direction:column;align-items:flex-start;gap:8px}.maathulp-mini__whatsapp{width:100%;justify-content:center}}

/* --- Verzending & Retour --- */
.verzending-retour{background:white;border-radius:16px;padding:32px;margin:32px 0;box-shadow:0 1px 3px rgba(0,0,0,0.03),0 4px 16px rgba(0,0,0,0.03)}
.verzending-retour__title{display:flex;align-items:center;gap:10px;font-family:'Bebas Neue',Impact,sans-serif;font-size:26px;color:#111;margin:0 0 24px;letter-spacing:.5px}
.verzending-retour__title-icon{font-size:28px}
.verzending-retour__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.verzending-retour__card{background:#f9f9f9;border-radius:14px;padding:24px}
.verzending-retour__card-header{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.verzending-retour__card-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:white}
.verzending-retour__card-icon--delivery{background:linear-gradient(135deg,#3B82F6 0%,#1D4ED8 100%)}
.verzending-retour__card-icon--return{background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%)}
.verzending-retour__card-header h3{font-size:20px;font-weight:700;color:#111;margin:0}
.verzending-retour__highlight{font-size:16px;color:#111;margin:0 0 16px;padding:12px 16px;background:white;border-radius:8px;border-left:4px solid var(--wvh-orange,#FF7900)}
.verzending-retour__explanation p{font-size:14px;line-height:1.6;color:#444;margin:0}
.verzending-retour__explanation{margin-bottom:16px}
.verzending-retour__list{list-style:none;padding:0;margin:0}
.verzending-retour__list li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;font-size:14px;color:#444}
.verzending-retour__check{color:#22c55e;font-weight:700;flex-shrink:0}
.verzending-retour__note{font-size:12px;color:#888;margin:12px 0 0;font-style:italic}
.verzending-retour__contact{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:24px;padding:18px 24px;background:linear-gradient(135deg,#FFFAF5 0%,#FFF4EB 100%);border:2px solid var(--wvh-orange,#FF7900);border-radius:12px}
.verzending-retour__contact-text{display:flex;align-items:center;gap:10px;font-size:14px;color:#444}
.verzending-retour__contact-icon{font-size:20px}
.verzending-retour__contact-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:#25D366;color:white;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s ease,transform .2s ease;white-space:nowrap}
.verzending-retour__contact-btn:hover{background:#128C7E;transform:translateY(-2px);color:white}
@media(max-width:768px){.verzending-retour{padding:24px 20px}.verzending-retour__title{font-size:22px}.verzending-retour__grid{grid-template-columns:1fr;gap:16px}.verzending-retour__card{padding:20px}.verzending-retour__contact{flex-direction:column;align-items:flex-start;gap:12px;padding:16px 18px}.verzending-retour__contact-btn{width:100%;justify-content:center}}

/* --- Hugo Widget --- */
.hugo-widget{background:#FFFAF5;border:1px solid var(--wvh-orange,#FF7900);border-radius:12px;padding:20px;margin-top:24px}
.hugo-widget__header{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.hugo-widget__icon{width:24px;height:24px;background:#22c55e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}
.hugo-widget__title{font-size:16px}
.hugo-widget__list{list-style:none;padding:0;margin:0 0 16px}
.hugo-widget__list li{display:flex;align-items:center;gap:8px;padding:8px 0;font-size:14px}
.hugo-widget__check{color:#22c55e;font-weight:700}
.hugo-widget__combo{background:#FFF2DB;border-left:3px solid #DC9814;padding:12px 16px;border-radius:6px;font-size:14px}
.hugo-widget__combo strong{display:block;margin-bottom:4px}
.hugo-widget__combo span{color:#666}

/* --- Hugo Card Mini --- */
.hugo-card-mini{position:relative;background:#fff;border:1px solid #e5e5e5;border-radius:12px;padding:16px 16px 16px 90px;margin-top:20px;box-shadow:0 1px 3px rgba(0,0,0,.03),0 4px 12px rgba(0,0,0,.03);min-height:120px}
.hugo-card-mini__photo{position:absolute;top:50%;left:16px;transform:translateY(-50%);width:60px;height:60px;border-radius:50%;overflow:hidden;border:2px solid var(--wvh-orange,#FF9800);box-shadow:0 2px 8px rgba(0,0,0,.12);background:#fff}
.hugo-card-mini__photo img{width:100%;height:100%;object-fit:cover;object-position:top}
.hugo-card-mini__content{display:flex;flex-direction:column;gap:10px}
.hugo-card-mini__name{display:block;font-size:14px;font-weight:600;color:#222}
.hugo-card-mini__usps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.hugo-card-mini__usps li{display:flex;align-items:center;gap:8px;font-size:13px;color:#444}
.hugo-card-mini__check{color:#4CAF50;font-weight:bold;font-size:14px}
.hugo-card-mini__whatsapp{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#25D366;color:white;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;transition:background .2s ease,transform .2s ease;margin-top:4px;width:fit-content}
.hugo-card-mini__whatsapp:hover{background:#128C7E;transform:translateY(-1px)}
.hugo-card-mini__whatsapp svg{flex-shrink:0}
@media(max-width:480px){.hugo-card-mini{padding:14px 14px 14px 14px;padding-top:70px;min-height:auto}.hugo-card-mini__photo{top:14px;left:14px;transform:none;width:50px;height:50px}.hugo-card-mini__header{padding-left:60px;margin-top:-56px;margin-bottom:8px;min-height:50px;display:flex;align-items:center}.hugo-card-mini__name{font-size:13px}.hugo-card-mini__usps li{font-size:12px}.hugo-card-mini__whatsapp{width:100%;justify-content:center}}

/* --- Waarom Hugo --- */
.waarom-hugo{background:linear-gradient(135deg,#f8fffe 0%,#f0fdf4 100%);border:2px solid #22c55e;border-radius:16px;padding:28px;margin:32px 0}
.waarom-hugo__title{display:flex;align-items:center;gap:10px;font-family:'Bebas Neue',Impact,sans-serif;font-size:24px;color:#111;margin:0 0 20px;letter-spacing:.5px}
.waarom-hugo__icon{font-size:28px}
.waarom-hugo__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.waarom-hugo__item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:white;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.03),0 4px 12px rgba(0,0,0,0.03);transition:transform .2s ease,box-shadow .2s ease}
.waarom-hugo__item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.waarom-hugo__item-icon{flex-shrink:0;width:44px;height:44px;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;color:white}
.waarom-hugo__item-icon--whatsapp{background:linear-gradient(135deg,#25D366 0%,#128C7E 100%)}
.waarom-hugo__item-content{flex:1;min-width:0}
.waarom-hugo__item-content strong{display:block;font-size:14px;font-weight:700;color:#111;margin-bottom:2px}
.waarom-hugo__item-content span{font-size:12px;color:#666}
.waarom-hugo__check{flex-shrink:0;width:24px;height:24px;background:#22c55e;color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}
.waarom-hugo__cta{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:20px;padding:14px 20px;background:#25D366;color:white;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s ease,transform .2s ease;box-shadow:0 4px 12px rgba(37,211,102,.3)}
.waarom-hugo__cta:hover{background:#128C7E;transform:translateY(-2px);box-shadow:0 6px 16px rgba(37,211,102,.4);color:white}
@media(max-width:768px){.waarom-hugo{padding:20px}.waarom-hugo__grid{grid-template-columns:1fr;gap:10px}.waarom-hugo__title{font-size:20px}.waarom-hugo__item{padding:12px 14px}.waarom-hugo__item-icon{width:40px;height:40px}.waarom-hugo__cta{font-size:13px;padding:12px 16px}}

/* --- Related Article Link in PDP --- */
.pdp-related-article{display:flex;align-items:center;gap:8px;margin-top:1.5rem;padding:12px 16px;background:var(--wvh-gray-50,#f9fafb);border:1px solid var(--wvh-gray-200,#e5e7eb);border-radius:8px;font-size:14px}.pdp-related-article svg{flex-shrink:0;color:var(--wvh-orange,#ff7900)}.pdp-related-article a{color:var(--wvh-orange,#ff7900);font-weight:600;text-decoration:none}.pdp-related-article a:hover{text-decoration:underline}

/* --- Variable PDP: mixed delivery speeds (subtle) --- */
.wvh-pdp-delivery{margin-bottom:10px}
.wvh-delivery-choice-hint{margin:0 0 6px;padding:6px 10px;font-size:12px;line-height:1.4;color:#6b7280;background:transparent;border-left:2px solid #e5e7eb}

/* --- Swatch disabled / out-of-stock state ---
   Duplicated from swatches.css so the rules survive LiteSpeed UCSS pruning.
   UCSS scans the rendered HTML for class names; .is-disabled / [disabled]
   are added by JS at runtime and therefore stripped from the critical CSS,
   leaving disabled swatches visually identical to available ones. Keeping
   the rules in pdp-components.css (which is enqueued unconditionally on
   product pages) guarantees the disabled state is always painted. */
.wvh-swatch.is-disabled,.wvh-swatch[disabled]{opacity:.4;cursor:not-allowed;pointer-events:none;position:relative;filter:grayscale(100%)}
.wvh-swatch.is-disabled .wvh-swatch__strike,.wvh-swatch[disabled] .wvh-swatch__strike{display:block;position:absolute;top:50%;left:-4px;right:-4px;height:3px;background:#e53935;transform:rotate(-45deg);border-radius:2px;box-shadow:0 1px 3px rgba(229,57,53,.5);z-index:10}
.wvh-swatch--color.is-disabled .wvh-swatch__strike,.wvh-swatch--color[disabled] .wvh-swatch__strike{left:-2px;right:-2px}
.wvh-swatch--size.is-disabled,.wvh-swatch--size[disabled],.wvh-swatch--text.is-disabled,.wvh-swatch--text[disabled]{background:#f8f8f8!important;border-color:#e0e0e0!important;color:#bbb!important}
.wvh-swatch--text.is-disabled .wvh-swatch__strike,.wvh-swatch--text[disabled] .wvh-swatch__strike{left:10%;right:10%;height:2px}
.wvh-swatch.is-disabled .wvh-swatch-tooltip,.wvh-swatch[disabled] .wvh-swatch-tooltip{background:#e53935}
.wvh-swatch.is-disabled .wvh-swatch-tooltip::after,.wvh-swatch[disabled] .wvh-swatch-tooltip::after{border-top-color:#e53935}
