/* =============================================================
   PRODUCT-PAGE — Single product conversion optimizations
   Created: 2026-03-31
   Loads on: is_product() only (enqueued in functions.php)
   Palette: Warm Atelier (--global-palette1 … --global-palette9)
   ============================================================= */


/* ==================== 1. TYPOGRAPHY ==================== */

/* Title — slightly tighter, warm dark */
.single-product .product_title.entry-title {
    line-height: 1.25 !important;
    margin-bottom: 6px !important;
}

/* Price — dark text instead of purple so the CTA owns the accent */
.single-product .price .woocommerce-Price-amount {
    color: var(--global-palette3) !important;
}

/* "tól" suffix — demoted so the number stays dominant */
.single-product .kwt-price-wrap .price .woocommerce-Price-suffix,
.single-product .kwt-price-wrap .price small.woocommerce-price-suffix {
    font-size: 0.8em !important;
    font-weight: 500 !important;
    color: var(--global-palette5) !important;
    margin-left: 2px !important;
}

/* Short description — fix the faint 0.55-opacity black */
.single-product .kwt-excerpt-wrap.woocommerce-product-details__short-description {
    color: var(--global-palette5) !important;
    opacity: 1 !important;
}

/* Bullet markers → purple micro-diamonds */
.single-product .kwt-excerpt-wrap ul {
    padding-left: 0 !important;
    list-style: none !important;
}

.single-product .kwt-excerpt-wrap ul li {
    position: relative;
    padding-left: 18px !important;
    margin-bottom: 6px !important;
}

.single-product .kwt-excerpt-wrap ul li::before {
    content: "\25C6"; /* ◆ */
    position: absolute;
    left: 0;
    top: 3px;
    color: var(--global-palette1);
    font-size: 8px;
}

.single-product .kwt-excerpt-wrap ul li strong {
    color: var(--global-palette3) !important;
}


/* ==================== 2. GALLERY ==================== */

/* Container — subtle card depth */
.single-product .woocommerce-product-gallery {
    background: var(--global-palette9) !important;
    border: 1px solid var(--global-palette6) !important;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.04) !important;
    border-radius: 16px !important;
    overflow: hidden !important;
}

/* Hover zoom hint */
.single-product .woocommerce-product-gallery__image img {
    transition: transform 0.35s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

.single-product .woocommerce-product-gallery__image:hover img {
    transform: scale(1.03);
}

/* Thumbnails */
.single-product .kadence-product-gallery-thumbnails {
    margin-top: 10px !important;
    padding-top: 10px !important;
    border-top: 1px solid var(--global-palette6) !important;
}

.single-product .kadence-product-gallery-thumbnails .splide__slide {
    border-radius: 8px !important;
    overflow: hidden !important;
    border: 2px solid transparent !important;
    transition: border-color 0.2s ease !important;
    cursor: pointer !important;
}

.single-product .kadence-product-gallery-thumbnails .splide__slide:hover,
.single-product .kadence-product-gallery-thumbnails .splide__slide.is-active {
    border-color: var(--global-palette1) !important;
}

/* Pagination dots */
.single-product .splide__pagination__page {
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    background: var(--global-palette6) !important;
    border: none !important;
    opacity: 1 !important;
    transition: all 0.2s ease !important;
}

.single-product .splide__pagination__page.is-active {
    background: var(--global-palette1) !important;
    transform: scale(1.35);
}


/* ==================== 3. CTA — ORANGE ACCENT ==================== */

/*  Override the purple gradient so the buy button pops.
    Uses palette2 (#E8793A) as hero colour.                        */

button.single_add_to_cart_button.button {
    height: 54px !important;
    border-radius: 12px !important;
    background: linear-gradient(135deg, #E8793A 0%, #D4622A 100%) !important;
    color: var(--global-palette9) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em !important;
    padding: 0 32px !important;
    box-shadow: 0 4px 14px rgba(232, 121, 58, 0.25) !important;
}

button.single_add_to_cart_button.button:hover {
    box-shadow: 0 8px 22px rgba(232, 121, 58, 0.35) !important;
}

button.single_add_to_cart_button.button:active {
    box-shadow: 0 2px 6px rgba(232, 121, 58, 0.18) !important;
}

/* Disabled stays neutral (already set in woocommerce.css, but reinforce) */
button.single_add_to_cart_button.button:disabled,
button.single_add_to_cart_button.button.disabled {
    background: var(--global-palette6) !important;
    color: var(--global-palette5) !important;
    box-shadow: none !important;
}

/* Mobile sticky bar — carry the orange through */
@media (max-width: 767px) {
    #kadence-mobile-sticky-add-to-cart button.single_add_to_cart_button {
        background: linear-gradient(135deg, #E8793A 0%, #D4622A 100%) !important;
        color: var(--global-palette9) !important;
        border-radius: 10px !important;
    }
}


/* ==================== 4. QUANTITY SELECTOR ==================== */

.single-product .quantity {
    display: flex !important;
    align-items: center !important;
    border: 2px solid var(--global-palette6) !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    background: var(--global-palette9) !important;
    height: 54px !important;
    transition: border-color 0.2s ease !important;
}

.single-product .quantity:focus-within {
    border-color: var(--global-palette1) !important;
}

.single-product .quantity input.qty {
    width: 48px !important;
    height: 100% !important;
    text-align: center !important;
    border: none !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--global-palette3) !important;
    background: transparent !important;
    -moz-appearance: textfield !important;
    outline: none !important;
    padding: 0 !important;
    line-height: 54px !important;
}

/* Hide native spinners */
.single-product .quantity input.qty::-webkit-outer-spin-button,
.single-product .quantity input.qty::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

/* Kadence +/- buttons */
.single-product .quantity .kb-quantity-minus,
.single-product .quantity .kb-quantity-plus,
.single-product .quantity.spinners-added input.minus,
.single-product .quantity.spinners-added input.plus {
    width: 40px !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    color: var(--global-palette5) !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    transition: all 0.15s ease !important;
    padding: 0 !important;
    line-height: 1 !important;
}

.single-product .quantity .kb-quantity-minus:hover,
.single-product .quantity .kb-quantity-plus:hover,
.single-product .quantity.spinners-added input.minus:hover,
.single-product .quantity.spinners-added input.plus:hover {
    background: var(--global-palette7) !important;
    color: var(--global-palette1) !important;
}


/* ==================== 5. MINI TRUST BAR (below CTA) ==================== */

/*  Injected via snippet / Kadence Element after the add-to-cart form.
    HTML contract:
    <div class="preem-mini-trust">
      <div class="preem-mini-trust-item">
        <svg …>…</svg> Gyors szállítás
      </div>
      …(×4)
    </div>                                                                  */

.preem-mini-trust {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-top: 20px;
    padding: 14px 16px;
    background: var(--global-palette7);
    border-radius: 12px;
    border: 1px solid var(--global-palette6);
    width: 100%;
    box-sizing: border-box;
}

.preem-mini-trust-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--global-palette5);
    line-height: 1.3;
    padding: 2px 0;
}

.preem-mini-trust-item svg {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    stroke: var(--global-palette1);
    stroke-width: 2;
    fill: none;
    opacity: 0.8;
}


/* ==================== 6. STOCK & DELIVERY ==================== */

/* Delivery row — tinted background so it doesn't vanish */
.single-product .fsm-delivery-info {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 12px !important;
    background: color-mix(in srgb, var(--global-palette1) 5%, transparent) !important;
    border-radius: 6px !important;
    margin: 0 !important;
}

.single-product .fsm-delivery-dates {
    font-weight: 700 !important;
    color: var(--global-palette3) !important;
}

/* Tighter coupling between badge + delivery */
.single-product .fsm-stock-wrapper {
    margin-bottom: 4px !important;
}


/* ==================== 7. COLOR SWATCHES ==================== */



/* Selected label */
.single-product .vi-wpvs-label-selected {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--global-palette3) !important;
}

/* Attribute row label ("Szín:") */
.single-product .variations th.label {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--global-palette3) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.03em !important;
    padding-bottom: 8px !important;
}


/* ==================== 8. STAR RATING / REVIEWS ==================== */

/* Rating row (shown via WC or Kadence block near title) */
.single-product .woocommerce-product-rating {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 10px !important;
}

.single-product .woocommerce-product-rating .star-rating {
    font-size: 14px !important;
    color: #F59E0B !important;
}

.single-product .woocommerce-product-rating .woocommerce-review-link {
    font-size: 13px !important;
    color: var(--global-palette5) !important;
    text-decoration: none !important;
}

.single-product .woocommerce-product-rating .woocommerce-review-link:hover {
    color: var(--global-palette1) !important;
}

/* Empty-reviews encouragement */
.single-product .woocommerce-noreviews {
    text-align: center !important;
    padding: 40px 20px !important;
    color: var(--global-palette5) !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
}


/* ==================== 9. SALE PRICE ==================== */

.single-product .price del {
    opacity: 0.55 !important;
    font-size: 0.85em !important;
    color: var(--global-palette5) !important;
    margin-right: 8px !important;
}

.single-product .price del .woocommerce-Price-amount {
    font-size: inherit !important;
    font-weight: 500 !important;
    color: inherit !important;
}

.single-product .price ins {
    text-decoration: none !important;
}

.single-product .price ins .woocommerce-Price-amount {
    color: var(--global-palette13) !important;
    font-weight: 800 !important;
}


/* ==================== 10. TAB WARM-UP ==================== */

/* Override stale Customizer tab styles */
.single-product div.product .woocommerce-tabs ul.tabs {
    border-bottom: none !important;
    padding-left: 0 !important;
}

.single-product div.product .woocommerce-tabs ul.tabs li {
    border: none !important;
    background-color: transparent !important;
}

.single-product div.product .woocommerce-tabs ul.tabs li.active {
    border-bottom: none !important;
}

/* Content copy — warmer */
.single-product .kt-tab-inner-content {
    color: var(--global-palette5) !important;
}


/* ==================== 11. CROSS-SELL / UPSELL ==================== */

/* Nomad related cards — palette alignment */
.single-product .preem3d-nomad-card {
    border-color: var(--global-palette6) !important;
    background: var(--global-palette9) !important;
    border-radius: 14px !important;
}

.single-product .preem3d-nomad-card:hover {
    border-color: var(--global-palette1) !important;
    box-shadow: 0 6px 16px rgba(109, 40, 217, 0.1) !important;
}

.single-product .preem3d-section-title {
    color: var(--global-palette3) !important;
}

.single-product .preem3d-add-btn,
.single-product .preem3d-view-btn {
    background: var(--global-palette7) !important;
    color: var(--global-palette3) !important;
    border-radius: 10px !important;
}

.single-product .preem3d-add-btn:hover,
.single-product .preem3d-view-btn:hover {
    background: var(--global-palette1) !important;
    color: var(--global-palette9) !important;
}


/* ==================== 12. SPACING ==================== */

.single-product .kwt-title-wrap  { margin-bottom: 4px !important; }
.single-product .kwt-price-wrap  { margin-bottom: 10px !important; }

.single-product form.cart .variations {
    margin-bottom: 16px !important;
}

.single-product .vi-wpvs-variation-wrap {
    margin-bottom: 20px !important;
}

.single-product .pewc-product-extra-groups-wrap {
    margin-bottom: 16px !important;
}

/* CWG notify button — consistent rounding */
body.single-product .product input.cwg_popup_submit {
    border-radius: 12px !important;
    height: 54px !important;
}


/* Now handled by the preem3d-featured-specs plugin CSS. */
    /* Gallery — drop border/shadow, full bleed */
    .single-product .woocommerce-product-gallery {
        border: none !important;
        box-shadow: none !important;
        border-radius: 12px !important;
    }

    /* Title */
    .single-product .product_title.entry-title {
        font-size: 1.3rem !important;
    }

    /* Price */
    .single-product .price .woocommerce-Price-amount {
        font-size: 1.45rem !important;
    }

    /* CTA full-width */
    button.single_add_to_cart_button.button {
        width: 100% !important;
        height: 50px !important;
        font-size: 15px !important;
        border-radius: 10px !important;
    }

    /* Quantity */
    .single-product .quantity {
        height: 50px !important;
    }

    .single-product .quantity input.qty {
        line-height: 50px !important;
    }

    /* ATC row */
    .single-product .woocommerce-variation-add-to-cart,
    .single-product form.cart:not(.variations_form) {
        flex-direction: row !important;
        gap: 10px !important;
    }

    /* Swatches */
    .single-product .vi-wpvs-option-color,
    .single-product .vi-wpvs-option-image {
        width: 36px !important;
        height: 36px !important;
    }

    /* Apple cards */
    .single-product [data-wpvs_attribute_name="attribute_pa_konfiguracio"] .vi-wpvs-option-wrap {
        padding: 14px 16px !important;
    }

    /* Short desc */
    .single-product .kwt-excerpt-wrap ul li {
        font-size: 13.5px !important;
    }

    /* Tabs */
    .single-product .kt-tabs-wrap {
        margin-top: 28px !important;
        padding-top: 18px !important;
    }

    /* Trust strip */
    .single-product .trust-strip-wrapper {
        padding: 10px 0 !important;
    }

    /* Mini trust */
    .preem-mini-trust {
        margin-top: 14px !important;
        padding: 12px !important;
    }

    /* Specs strip → 2×2 */
    .preem-specs-strip {
        flex-wrap: wrap;
    }

    .preem-spec-item {
        flex: 1 1 45%;
        padding: 12px 8px;
    }

    .preem-spec-item:nth-child(2n)::after {
        display: none;
    }

    .preem-spec-item:nth-child(-n+2) {
        border-bottom: 1px solid var(--global-palette6);
    }
}

@media (max-width: 480px) {
    /* Mini trust stacks to 1-col on very small screens */
    .preem-mini-trust {
        grid-template-columns: 1fr;
        gap: 4px;
    }
}


/* ==================== 15. MICRO-INTERACTIONS ==================== */

/* Focus ring for keyboard users */
.single-product button:focus-visible,
.single-product a:focus-visible,
.single-product input:focus-visible,
.single-product select:focus-visible {
    outline: 2px solid var(--global-palette1) !important;
    outline-offset: 2px !important;
}

/* Respect reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .single-product *,
    .single-product *::before,
    .single-product *::after {
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
    }
}
