/**
 * Paperchase Shop — WooCommerce (catalog, product, cart, checkout, account).
 * Loads after hub.css on shop routes — uses .pcs-retail-dark tokens.
 */

/* —— Alle Woo-routes: zelfde horizontale ritme als header (geen “verspringende” pagina’s) —— */
body.pcs-woo-shop {
    --pcs-woo-gutter: clamp(1rem, 4vw, 2.5rem);
    --pcs-woo-content-max: min(92rem, 100%);
}

/*
 * Customizer «Winkel — paginatitels» — body.pcs-hide-wc-page-titles
 * Shop + producttaxonomie: H1 via filter weg (woocommerce_show_page_title).
 * Winkelwagen / afrekenen / account / blok-titels: hier verborgen.
 * Geen .single-product — productnaam blijft zichtbaar.
 */
body.pcs-hide-wc-page-titles.woocommerce-cart .entry-header,
body.pcs-hide-wc-page-titles.woocommerce-checkout .entry-header,
body.pcs-hide-wc-page-titles.woocommerce-account .entry-header,
body.pcs-hide-wc-page-titles.woocommerce-order-received .entry-header {
    display: none !important;
}

body.pcs-hide-wc-page-titles.woocommerce-cart h1.wp-block-post-title,
body.pcs-hide-wc-page-titles.woocommerce-checkout h1.wp-block-post-title,
body.pcs-hide-wc-page-titles.woocommerce-account h1.wp-block-post-title,
body.pcs-hide-wc-page-titles.woocommerce-order-received h1.wp-block-post-title {
    display: none !important;
}

body.pcs-hide-wc-page-titles.woocommerce-cart .woocommerce-cart-form__cart-title {
    display: none !important;
}

/* Shop als pagina met blokken (geen klassiek archief): eerste titelblok */
body.pcs-hide-wc-page-titles.woocommerce-shop:not(.single-product) .wp-block-post-title:first-of-type {
    display: none !important;
}

body.pcs-shop-catalog-test.pcs-hide-wc-page-titles .woocommerce-products-header__title {
    display: none !important;
}

/* —— Catalog —— */
.pcs-woo-wrap {
    width: 100%;
    max-width: var(--pcs-woo-content-max, min(92rem, 100%));
    margin-inline: auto;
    padding-bottom: 3rem;
    box-sizing: border-box;
}

.pcs-woo-shop .site-main {
    max-width: 100%;
    padding-left: var(--pcs-woo-gutter, clamp(1rem, 4vw, 2.5rem));
    padding-right: var(--pcs-woo-gutter, clamp(1rem, 4vw, 2.5rem));
    padding-top: 1.5rem;
    padding-bottom: 3rem;
    font-family: var(--pcs-font-body, "Poppins", system-ui, sans-serif);
    color: var(--pcs-text-primary, #f2f2f2);
    box-sizing: border-box;
}

.pcs-woo-shop .woocommerce-result-count,
.pcs-woo-shop .woocommerce-ordering label,
.pcs-woo-shop .woocommerce-ordering select {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.6875rem;
}

.pcs-woo-shop .pcs-product-card .woocommerce-loop-product__title {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    letter-spacing: 0.06em;
}

.pcs-woo-shop .woocommerce-breadcrumb {
    margin: 0 0 1.5rem;
    font-size: 0.75rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--pcs-muted, rgba(242, 242, 242, 0.62));
}

.pcs-woo-shop .woocommerce-breadcrumb a {
    color: var(--pcs-publishing-gold);
    text-decoration: none;
}

.pcs-woo-shop .woocommerce-breadcrumb a:hover {
    text-decoration: underline;
}

.pcs-woo-shop .woocommerce-products-header {
    margin-bottom: 2rem;
}

/* Resultaten + sortering (toolbar-wrapper uit woocommerce-theme.php) */
.pcs-woo-shop .pcs-woo-shop-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.75rem;
}

.pcs-woo-shop .pcs-woo-shop-toolbar .woocommerce-result-count,
.pcs-woo-shop .pcs-woo-shop-toolbar .woocommerce-ordering {
    margin: 0;
}

.pcs-woo-shop .woocommerce-products-header__title {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    margin: 0 0 0.5rem;
    color: #fff;
}

.pcs-woo-shop .woocommerce-ordering select {
    background: rgba(20, 20, 20, 0.95);
    color: #fff;
    border: 1px solid color-mix(in srgb, var(--pcs-publishing-gold) 25%, transparent);
    border-radius: 9px;
    padding: 0.55rem 2rem 0.55rem 0.75rem;
    min-height: 2.75rem;
}

@media (max-width: 599px) {
    .pcs-woo-shop .pcs-woo-shop-toolbar {
        flex-direction: column;
        align-items: stretch;
        gap: 0.85rem;
    }

    .pcs-woo-shop .pcs-woo-shop-toolbar .woocommerce-ordering {
        width: 100%;
    }

    .pcs-woo-shop .woocommerce-ordering select {
        width: 100%;
    }

    .pcs-woo-shop .woocommerce-result-count {
        text-align: center;
    }
}

/*
 * Product grid — mobiel (<900px): 2 kolommen, compacte gap.
 * Tablet (900–1199px): columns-3 = 3 kolommen (klassiek + blok-shop), strakke gap.
 * Desktop (1200px+): zelfde kolomlogica, iets ruimere gap.
 */
.pcs-woo-shop ul.products {
    display: grid !important;
    /* Default 2 kolommen i.p.v. 1 — voorkomt “1 kaart breed” vóór media-queries */
    grid-template-columns: repeat(var(--woo-cols, 2), minmax(0, 1fr));
    gap: 1.05rem;
    list-style: none;
    margin: 0 !important;
    padding: 0 !important;
    /* Strak raster: gelijke rijen, geen ‘zwevende’ cellen */
    align-items: stretch;
    justify-items: stretch;
    align-content: start;
    grid-auto-flow: row;
}

@media (max-width: 899px) {
    .pcs-woo-shop ul.products {
        --woo-cols: 2;
        gap: clamp(0.5rem, 2.5vw, 0.9rem);
    }

    /* Woo smallscreen.css: float op li.product — grid-items moeten geen float width hebben */
    .pcs-woo-shop ul.products li.product {
        float: none !important;
        clear: none !important;
        width: auto !important;
        max-width: none !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Geen volle-breedte-centrering van laatste oneven item — dat gaf 2+1 / “1-2-1”-gevoel op mobiel. */
}

@media (max-width: 599px) {
    .pcs-woo-shop ul.products {
        gap: clamp(0.45rem, 2.2vw, 0.85rem);
    }
}

/* 900–1199px: columns-3 = 3 kolommen (zelfde als desktop), strak raster */
@media (min-width: 900px) and (max-width: 1199px) {
    .pcs-woo-shop ul.products {
        gap: clamp(0.85rem, 1.35vw, 1.15rem);
        row-gap: clamp(0.95rem, 1.45vw, 1.25rem);
        column-gap: clamp(0.85rem, 1.35vw, 1.15rem);
    }

    .pcs-woo-shop ul.products.columns-2 {
        --woo-cols: 2;
    }

    .pcs-woo-shop ul.products.columns-3 {
        --woo-cols: 3;
    }

    .pcs-woo-shop ul.products.columns-4 {
        --woo-cols: 2;
    }

    .pcs-woo-shop ul.products.columns-5,
    .pcs-woo-shop ul.products.columns-6 {
        --woo-cols: 3;
    }

    /* Geen last-child oneven-centrering — consistente rijen */
}

@media (min-width: 1200px) {
    .pcs-woo-shop ul.products {
        gap: clamp(1rem, 1.25vw, 1.45rem);
        row-gap: clamp(1.05rem, 1.35vw, 1.5rem);
        column-gap: clamp(1rem, 1.25vw, 1.45rem);
    }

    .pcs-woo-shop ul.products.columns-2 {
        --woo-cols: 2;
    }

    .pcs-woo-shop ul.products.columns-3 {
        --woo-cols: 3;
    }

    .pcs-woo-shop ul.products.columns-4 {
        --woo-cols: 4;
    }

    .pcs-woo-shop ul.products.columns-5,
    .pcs-woo-shop ul.products.columns-6 {
        --woo-cols: 4;
    }

    /* 3-kol grid: geen volle-breedte-centrering van enkele laatste rij — gewone grid-flow (1e kolom volgende rij). */
    /* Geen aparte «oneven laatste»-regel voor related/upsells: die maakte de 3e tegel smal/gecentreerd. */
}

/* Product card */
/*
 * Archief: kaarten gelijke hoogte in het grid; mediavlak vast 1:1 (niet afhankelijk van foto-intrinsics).
 */
.pcs-woo-shop ul.products li.product.pcs-product-card {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
    align-self: stretch;
    height: 100%;
}

.pcs-product-card__inner {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    min-height: 0;
    background: rgba(12, 12, 12, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    overflow: hidden;
    transition:
        box-shadow 0.22s ease-out,
        border-color 0.22s ease-out,
        transform 0.22s ease-out;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.pcs-product-card:hover .pcs-product-card__inner {
    border-color: color-mix(in srgb, var(--pcs-publishing-gold) 35%, transparent);
    box-shadow:
        0 16px 40px rgba(0, 0, 0, 0.45),
        0 0 0 1px color-mix(in srgb, var(--pcs-publishing-gold) 12%, transparent);
    transform: translateY(-3px);
}

.pcs-woo-shop .pcs-product-card .woocommerce-loop-product__link {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
    position: relative;
    text-decoration: none;
    color: inherit;
}

/*
 * Vast mediavlak: altijd vierkant vullend; cover = uitsnedes gelijk i.p.v. verschillende aspect ratios.
 * Geen border-radius op img — afronding alleen via .pcs-product-card__inner (overflow:hidden).
 * Geen alleen “> img”: sommige setups wrappen de thumbnail (plugins / theme).
 */
.pcs-woo-shop .pcs-product-card .woocommerce-loop-product__link img,
.pcs-woo-shop .pcs-product-card a.woocommerce-LoopProduct-link img {
    width: 100%;
    max-width: 100%;
    aspect-ratio: 1 / 1;
    height: auto;
    min-height: 0;
    object-fit: cover;
    object-position: center;
    display: block;
    flex: 0 0 auto;
    vertical-align: bottom;
    background-color: rgba(0, 0, 0, 0.28);
    border-radius: 0;
}

/* Placeholder / “geen foto”: zelfde kader, icoon netjes gecentreerd (alle breakpoints gelijk) */
.pcs-woo-shop .pcs-product-card img.woocommerce-placeholder {
    object-fit: contain;
    object-position: center;
    padding: clamp(0.65rem, 3.5vw, 1.15rem);
    background: rgba(0, 0, 0, 0.38);
    box-sizing: border-box;
}

/*
 * Product grids (blokken):
 * — Legacy: .wc-block-grid__products
 * — WC 9.5+ Product Collection: ul.wc-block-product-template (flex), niet .wc-block-grid
 */
@media (max-width: 899px) {
    body.paperchase-shop-theme .wc-block-grid .wc-block-grid__products,
    .pcs-woo-shop .wc-block-grid .wc-block-grid__products,
    .wc-block-grid .wc-block-grid__products {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: clamp(0.45rem, 2.2vw, 0.85rem) !important;
    }

    .wp-block-woocommerce-product-collection ul.wc-block-product-template,
    body.paperchase-shop-theme ul.wc-block-product-template,
    .pcs-woo-shop ul.wc-block-product-template {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: clamp(0.45rem, 2.2vw, 0.85rem) !important;
    }

    .wp-block-woocommerce-product-collection ul.wc-block-product-template > li,
    body.paperchase-shop-theme ul.wc-block-product-template > li,
    .pcs-woo-shop ul.wc-block-product-template > li {
        width: auto !important;
        max-width: none !important;
        min-width: 0 !important;
        flex: none !important;
        margin: 0 !important;
    }

}

/* Blok-shop: zelfde breakpoint als klassieke loop — grotere kaarten op tablet / groot scherm */
@media (min-width: 900px) and (max-width: 1199px) {
    /* columns-2: ontbrak — anders valt WC-blocks terug op flex / vreemde rijen (1-2-1) */
    .wc-block-grid[class*="columns-2"] .wc-block-grid__products,
    ul.wc-block-grid__products[class*="columns-2"],
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.columns-2,
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.is-flex-container.columns-2,
    body.paperchase-shop-theme ul.wc-block-product-template.columns-2,
    .pcs-woo-shop ul.wc-block-product-template.columns-2 {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: clamp(0.85rem, 1.35vw, 1.15rem) !important;
        row-gap: clamp(0.95rem, 1.45vw, 1.25rem) !important;
        column-gap: clamp(0.85rem, 1.35vw, 1.15rem) !important;
    }

    .wc-block-grid[class*="columns-3"] .wc-block-grid__products,
    ul.wc-block-grid__products[class*="columns-3"],
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.columns-3,
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.is-flex-container.columns-3,
    body.paperchase-shop-theme ul.wc-block-product-template.columns-3,
    .pcs-woo-shop ul.wc-block-product-template.columns-3 {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: clamp(0.85rem, 1.35vw, 1.15rem) !important;
        row-gap: clamp(0.95rem, 1.45vw, 1.25rem) !important;
        column-gap: clamp(0.85rem, 1.35vw, 1.15rem) !important;
    }

    .wc-block-grid[class*="columns-4"] .wc-block-grid__products,
    ul.wc-block-grid__products[class*="columns-4"],
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.columns-4,
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.is-flex-container.columns-4,
    body.paperchase-shop-theme ul.wc-block-product-template.columns-4,
    .pcs-woo-shop ul.wc-block-product-template.columns-4 {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: clamp(0.85rem, 1.35vw, 1.15rem) !important;
        row-gap: clamp(0.95rem, 1.45vw, 1.25rem) !important;
        column-gap: clamp(0.85rem, 1.35vw, 1.15rem) !important;
    }

}

@media (min-width: 1200px) {
    .wc-block-grid[class*="columns-2"] .wc-block-grid__products,
    ul.wc-block-grid__products[class*="columns-2"],
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.columns-2,
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.is-flex-container.columns-2,
    body.paperchase-shop-theme ul.wc-block-product-template.columns-2,
    .pcs-woo-shop ul.wc-block-product-template.columns-2 {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: clamp(1rem, 1.25vw, 1.45rem) !important;
        row-gap: clamp(1.05rem, 1.35vw, 1.5rem) !important;
        column-gap: clamp(1rem, 1.25vw, 1.45rem) !important;
    }

    .wc-block-grid[class*="columns-3"] .wc-block-grid__products,
    ul.wc-block-grid__products[class*="columns-3"],
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.columns-3,
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.is-flex-container.columns-3,
    body.paperchase-shop-theme ul.wc-block-product-template.columns-3,
    .pcs-woo-shop ul.wc-block-product-template.columns-3 {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: clamp(1rem, 1.25vw, 1.45rem) !important;
        row-gap: clamp(1.05rem, 1.35vw, 1.5rem) !important;
        column-gap: clamp(1rem, 1.25vw, 1.45rem) !important;
    }

    .wc-block-grid[class*="columns-4"] .wc-block-grid__products,
    ul.wc-block-grid__products[class*="columns-4"],
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.columns-4,
    .wp-block-woocommerce-product-collection ul.wc-block-product-template.is-flex-container.columns-4,
    body.paperchase-shop-theme ul.wc-block-product-template.columns-4,
    .pcs-woo-shop ul.wc-block-product-template.columns-4 {
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        gap: clamp(1rem, 1.25vw, 1.45rem) !important;
        row-gap: clamp(1.05rem, 1.35vw, 1.5rem) !important;
        column-gap: clamp(1rem, 1.25vw, 1.45rem) !important;
    }

    /* Geen kunstmatige grid-column voor laatste rij (2 of 1 items) — puur flow in het 3-kol raster. */
}

@media (max-width: 781px) {
    body.paperchase-shop-theme .wc-block-grid__product-image img.woocommerce-placeholder,
    .pcs-woo-shop .wc-block-grid__product-image img.woocommerce-placeholder {
        object-fit: contain;
        padding: clamp(0.35rem, 3.5vw, 0.65rem);
        background: rgba(0, 0, 0, 0.28);
        box-sizing: border-box;
    }
}

/*
 * Woo Blocks — producttegels (Gutenberg grid / Product Collection):
 * zelfde retail-DNA als .pcs-product-card__inner; afbeelding alleen in parent met overflow (geen dubbele radius op img).
 */
.pcs-woo-shop .wc-block-grid .wc-block-grid__products > li.wc-block-grid__product,
.pcs-woo-shop ul.wc-block-product-template > li.wc-block-product {
    min-width: 0;
    display: flex;
    flex-direction: column;
    height: 100%;
    box-sizing: border-box;
    background: rgba(12, 12, 12, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    overflow: hidden;
    transition:
        box-shadow 0.22s ease-out,
        border-color 0.22s ease-out,
        transform 0.22s ease-out;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.pcs-woo-shop .wc-block-grid .wc-block-grid__products > li.wc-block-grid__product:hover,
.pcs-woo-shop ul.wc-block-product-template > li.wc-block-product:hover {
    border-color: color-mix(in srgb, var(--pcs-publishing-gold) 35%, transparent);
    box-shadow:
        0 16px 40px rgba(0, 0, 0, 0.45),
        0 0 0 1px color-mix(in srgb, var(--pcs-publishing-gold) 12%, transparent);
    transform: translateY(-3px);
}

.pcs-woo-shop .wc-block-grid__product-image,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-image,
.pcs-woo-shop ul.wc-block-product-template > li.wc-block-product > figure:first-child,
.pcs-woo-shop ul.wc-block-product-template > li.wc-block-product > .wp-block-post-featured-image:first-child {
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.22);
    line-height: 0;
    flex-shrink: 0;
}

.pcs-woo-shop .wc-block-grid__product-image a,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-image a {
    display: block;
    line-height: 0;
}

.pcs-woo-shop .wc-block-grid__product-image img,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-image img,
.pcs-woo-shop ul.wc-block-product-template > li.wc-block-product figure img,
.pcs-woo-shop ul.wc-block-product-template > li.wc-block-product .wp-block-post-featured-image img {
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-title,
.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-price,
.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-add-to-cart,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-title,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-price,
.pcs-woo-shop ul.wc-block-product-template .wc-block-grid__product-add-to-cart {
    padding-left: 1.1rem;
    padding-right: 1.1rem;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-title,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-title {
    margin: 0;
    padding-top: 1rem;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.25;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-title a,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-title a {
    color: #fff !important;
    text-decoration: none;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-title a:hover,
.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-title a:focus-visible,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-title a:hover,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-title a:focus-visible {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

/* Blok-shop: zelfde prijs-DNA als klassieke kaart (Poppins, neutraal + goud op sale) */
.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-price,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-price {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.4rem 0.65rem;
    box-sizing: border-box;
    width: 100%;
    margin: 0.2rem 0 0;
    padding: 0 0 0.5rem;
    border: none;
    font-family: var(--pcs-font-body, "Poppins", system-ui, sans-serif);
    font-weight: 500;
    font-size: 1rem;
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1, "lnum" 1;
    letter-spacing: 0.01em;
    line-height: 1.35;
    color: rgba(255, 255, 255, 0.9) !important;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-price .woocommerce-Price-currencySymbol,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-price .woocommerce-Price-currencySymbol {
    font-weight: 500;
    margin-right: 0.1em;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-price del,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-price del {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--pcs-text-muted, rgba(242, 242, 242, 0.5)) !important;
    text-decoration: line-through;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.12em;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-price ins,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-price ins {
    text-decoration: none;
    font-weight: 600;
    background: none;
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

.pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-add-to-cart,
.pcs-woo-shop ul.wc-block-product-template .wc-block-grid__product-add-to-cart,
.pcs-woo-shop ul.wc-block-product-template .wp-block-woocommerce-product-button {
    margin-top: auto;
    padding-bottom: 1.15rem;
}

@media (min-width: 1200px) {
    .pcs-woo-shop .wc-block-grid .wc-block-grid__products > li.wc-block-grid__product,
    .pcs-woo-shop ul.wc-block-product-template > li.wc-block-product {
        border-radius: 18px;
    }
}

/*
 * Sale badge — Customizer «Winkel — aanbiedingsbadge» (inc/shop-sale-badge.php).
 * Zelfde DNA als .pcs-info-btn: skew, distribution-blauw, witte onderrand, Heavy uppercase.
 */
.pcs-woo-shop .pcs-product-card > span.onsale:not(.pcs-sale-badge) {
    position: absolute;
    top: 0.65rem;
    left: 0.65rem;
    z-index: 2;
    background: var(--pcs-bookings-red);
    color: #fff;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    padding: 0.35rem 0.6rem;
    border-radius: 6px;
    line-height: 1;
    min-height: unset;
    min-width: unset;
}

.pcs-woo-shop ul.products li.product > span.onsale:not(.pcs-sale-badge),
.pcs-woo-shop .related.products ul.products li.product > span.onsale:not(.pcs-sale-badge),
.pcs-woo-shop .upsells.products ul.products li.product > span.onsale:not(.pcs-sale-badge) {
    position: absolute;
    z-index: 2;
    top: 0.65rem;
    left: 0.65rem;
    min-height: auto;
    min-width: auto;
    padding: 0.35rem 0.65rem;
    border-radius: 6px;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    background: var(--pcs-bookings-red);
    color: #fff;
    line-height: 1.3;
    box-sizing: border-box;
}

/* —— pcs-sale-badge (Petjes-logica + Paperchase-knopstijl) —— */
.pcs-woo-shop ul.products li.product span.pcs-sale-badge,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge {
    --pcs-sale-mult: 1;
    position: absolute;
    z-index: 4;
    min-height: auto;
    min-width: auto;
    box-sizing: border-box;
    pointer-events: none;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge .pcs-sale-badge__inner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__inner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__inner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge .pcs-sale-badge__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: calc(0.15rem * var(--pcs-sale-mult));
    text-align: center;
}

/* Pill + minimal: skew-CTA — translateZ(0) + smoothing tegen wazige tekst op skew */
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--pill,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--pill,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--pill,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--pill,
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--minimal,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--minimal,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--minimal,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--minimal {
    padding: calc(0.35rem * var(--pcs-sale-mult)) calc(0.65rem * var(--pcs-sale-mult));
    background: var(--pcs-distribution-blue, #173cc8);
    color: #fff;
    border: none;
    border-bottom: 5px solid #fff;
    border-radius: 0;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-size: calc(0.625rem * var(--pcs-sale-mult));
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.25;
    transform: skew(-10deg) translateZ(0);
    box-shadow: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--pill .pcs-sale-badge__inner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--pill .pcs-sale-badge__inner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--pill .pcs-sale-badge__inner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--pill .pcs-sale-badge__inner,
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--minimal .pcs-sale-badge__inner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--minimal .pcs-sale-badge__inner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--minimal .pcs-sale-badge__inner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--minimal .pcs-sale-badge__inner {
    transform: skew(10deg) translateZ(0);
    backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--minimal,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--minimal,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--minimal,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--minimal {
    background: transparent !important;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.85) !important;
    border-bottom: 5px solid var(--pcs-publishing-gold, #ffcb00) !important;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--primary,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--primary,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--primary,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge .pcs-sale-badge__line--primary,
.pcs-woo-shop ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--secondary,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--secondary,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--secondary,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge .pcs-sale-badge__line--secondary {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1, "lnum" 1;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--secondary,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--secondary,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge .pcs-sale-badge__line--secondary,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge .pcs-sale-badge__line--secondary {
    font-size: calc(0.55rem * var(--pcs-sale-mult));
    letter-spacing: 0.05em;
    opacity: 0.95;
    font-weight: 600;
}

/* Cirkel: geen skew, wel zelfde kleuren */
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--circle,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--circle,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--circle,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--circle {
    width: calc(3.75rem * var(--pcs-sale-mult));
    height: calc(3.75rem * var(--pcs-sale-mult));
    padding: calc(0.35rem * var(--pcs-sale-mult)) calc(0.4rem * var(--pcs-sale-mult));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1.25;
    transform: none;
    background: var(--pcs-distribution-blue, #173cc8);
    color: #fff;
    border: none;
    border-bottom: 5px solid #fff;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-size: calc(0.6rem * var(--pcs-sale-mult));
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--circle .pcs-sale-badge__inner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--circle .pcs-sale-badge__inner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--circle .pcs-sale-badge__inner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--circle .pcs-sale-badge__inner {
    transform: none;
    max-width: 100%;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--circle.pcs-sale-badge--two-line,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--circle.pcs-sale-badge--two-line,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--circle.pcs-sale-badge--two-line,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--circle.pcs-sale-badge--two-line {
    width: calc(4.35rem * var(--pcs-sale-mult));
    height: calc(4.35rem * var(--pcs-sale-mult));
    font-size: calc(0.52rem * var(--pcs-sale-mult));
}

/*
 * Hoeklint — clip vierkant schaalt met --pcs-sale-mult; lintpositie in % van die box zodat elke
 * grootte (70–200%) diagonaal tegen de tegelhoek blijft (niet vaste rem die uit verhouding raakt).
 * Lintbreedte = 7/5.25 × zijde van de clip.
 */
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner {
    padding: 0;
    width: calc(5.25rem * var(--pcs-sale-mult));
    height: calc(5.25rem * var(--pcs-sale-mult));
    overflow: hidden;
    background: transparent !important;
    color: #fff;
    border-radius: 0;
    font-size: calc(0.6rem * var(--pcs-sale-mult));
    transform: none;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__inner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__inner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__inner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner .pcs-sale-badge__inner {
    position: absolute;
    inset: 0;
    align-items: flex-start;
    justify-content: flex-start;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__corner-rot,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__corner-rot,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__corner-rot,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner .pcs-sale-badge__corner-rot {
    position: absolute;
    width: 133.333333%;
    max-width: none;
    box-sizing: border-box;
    padding: calc(0.35rem * var(--pcs-sale-mult)) 0;
    text-align: center;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    background: var(--pcs-distribution-blue, #173cc8);
    color: #fff;
    border: none;
    border-bottom: calc(5px * var(--pcs-sale-mult)) solid #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: calc(0.1rem * var(--pcs-sale-mult));
    line-height: 1.25;
    transform-origin: center;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__line--secondary,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__line--secondary,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner .pcs-sale-badge__line--secondary,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner .pcs-sale-badge__line--secondary {
    font-size: calc(0.5rem * var(--pcs-sale-mult));
}

/* Posities (loop + single) — pill/cirkel/minimal: lichte inset */
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--pos-tl,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--pos-tl,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--pos-tl,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--pos-tl {
    top: 0.65rem;
    left: 0.65rem;
    right: auto;
    bottom: auto;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--pos-tr,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--pos-tr,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--pos-tr,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--pos-tr {
    top: 0.65rem;
    right: 0.65rem;
    left: auto;
    bottom: auto;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--pos-bl,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--pos-bl,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--pos-bl,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--pos-bl {
    bottom: 0.65rem;
    left: 0.65rem;
    top: auto;
    right: auto;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--pos-br,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--pos-br,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--pos-br,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--pos-br {
    bottom: 0.65rem;
    right: 0.65rem;
    top: auto;
    left: auto;
}

/* Hoeklint: clipbox strak in de hoek van de kaart (inner heeft position:relative) */
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl {
    top: 0;
    left: 0;
    right: auto;
    bottom: auto;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr {
    top: 0;
    right: 0;
    left: auto;
    bottom: auto;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl {
    bottom: 0;
    left: 0;
    top: auto;
    right: auto;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br {
    bottom: 0;
    right: 0;
    top: auto;
    left: auto;
}

/* Lint in % van clipbox: 20% / -35.2381% = vroeger 1.05rem / -1.85rem t.o.v. 5.25rem (alle schalen gelijk) */
.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr .pcs-sale-badge__corner-rot,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr .pcs-sale-badge__corner-rot,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr .pcs-sale-badge__corner-rot,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tr .pcs-sale-badge__corner-rot {
    top: 20%;
    right: -35.2381%;
    left: auto;
    bottom: auto;
    transform: rotate(45deg);
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl .pcs-sale-badge__corner-rot,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl .pcs-sale-badge__corner-rot,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl .pcs-sale-badge__corner-rot,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-tl .pcs-sale-badge__corner-rot {
    top: 20%;
    left: -35.2381%;
    right: auto;
    bottom: auto;
    transform: rotate(-45deg);
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__inner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__inner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__inner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__inner {
    align-items: flex-end;
    justify-content: flex-end;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__corner-rot,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__corner-rot,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__corner-rot,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-br .pcs-sale-badge__corner-rot {
    bottom: 20%;
    right: -35.2381%;
    top: auto;
    left: auto;
    transform: rotate(-45deg);
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__inner,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__inner,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__inner,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__inner {
    align-items: flex-start;
    justify-content: flex-end;
}

.pcs-woo-shop ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__corner-rot,
.pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__corner-rot,
.pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__corner-rot,
.pcs-woo-shop.single-product div.product span.pcs-sale-badge--corner.pcs-sale-badge--pos-bl .pcs-sale-badge__corner-rot {
    bottom: 20%;
    left: -35.2381%;
    top: auto;
    right: auto;
    transform: rotate(45deg);
}

.pcs-woo-shop .pcs-product-card__body {
    flex: 1 1 auto;
    min-height: 0;
    padding: 1rem 1.1rem 1.15rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

/* Tablet/desktop: iets ruimer dan mobiel */
@media (min-width: 900px) {
    .pcs-woo-shop .pcs-product-card__body {
        padding: 1.1rem 1.15rem 1.25rem;
        gap: 0.7rem;
    }
}

/* Groot scherm: duidelijk grotere typografie + kaart (contrast met mobiel) */
@media (min-width: 1200px) {
    .pcs-product-card__inner {
        border-radius: 18px;
    }

    .pcs-woo-shop .pcs-product-card__body {
        padding: 1.25rem 1.35rem 1.4rem;
        gap: 0.85rem;
    }

    .pcs-woo-shop .pcs-product-card .woocommerce-loop-product__title {
        font-size: 1.0625rem;
        letter-spacing: 0.04em;
    }

    .pcs-woo-shop .pcs-product-card .price {
        font-size: 1.0625rem;
    }

    .pcs-woo-shop .wc-block-grid__product .wc-block-grid__product-price,
    .pcs-woo-shop ul.wc-block-product-template .wc-block-components-product-price {
        font-size: 1.0625rem;
    }

    .pcs-woo-shop ul.products li.product span.pcs-sale-badge--pill,
    .pcs-woo-shop ul.products li.product span.pcs-sale-badge--minimal,
    .pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--pill,
    .pcs-woo-shop .related.products ul.products li.product span.pcs-sale-badge--minimal,
    .pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--pill,
    .pcs-woo-shop .upsells.products ul.products li.product span.pcs-sale-badge--minimal,
    .pcs-woo-shop.single-product div.product span.pcs-sale-badge--pill,
    .pcs-woo-shop.single-product div.product span.pcs-sale-badge--minimal {
        font-size: calc(0.6875rem * var(--pcs-sale-mult, 1));
        padding: calc(0.4rem * var(--pcs-sale-mult, 1)) calc(0.65rem * var(--pcs-sale-mult, 1));
    }
}

.pcs-woo-shop .pcs-product-card .woocommerce-loop-product__title {
    font-family: var(--pcs-font-display, "Jost", sans-serif);
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    margin: 0;
    line-height: 1.25;
}

.pcs-woo-shop .pcs-product-card .woocommerce-loop-product__title a {
    color: #fff;
    text-decoration: none;
}

.pcs-woo-shop .pcs-product-card .woocommerce-loop-product__title a:hover {
    color: var(--pcs-publishing-gold);
}

.pcs-woo-shop .pcs-product-card .star-rating {
    color: var(--pcs-publishing-gold);
}

/*
 * Shop-archief — prijs (UX: hiërarchie, geen «divider»-lijn; Poppins i.p.v. display-Heavy).
 * Basis: hoog-contrast neutraal; merk-goud alleen op actuele sale-prijs (ins).
 */
.pcs-woo-shop .pcs-product-card .price {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.4rem 0.65rem;
    box-sizing: border-box;
    width: 100%;
    margin: 0.2rem 0 0;
    padding: 0;
    border: none;
    font-family: var(--pcs-font-body, "Poppins", system-ui, sans-serif);
    font-size: 1rem;
    font-weight: 500;
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1, "lnum" 1;
    letter-spacing: 0.01em;
    line-height: 1.35;
    color: rgba(255, 255, 255, 0.9);
}

.pcs-woo-shop .pcs-product-card .price .woocommerce-Price-amount {
    font-weight: inherit;
}

.pcs-woo-shop .pcs-product-card .price .woocommerce-Price-currencySymbol {
    font-weight: 500;
    margin-right: 0.1em;
}

.pcs-woo-shop .pcs-product-card .price del {
    margin: 0;
    padding: 0;
    font-size: 0.8125rem;
    font-weight: 500;
    font-style: normal;
    letter-spacing: 0;
    color: var(--pcs-text-muted, rgba(242, 242, 242, 0.5));
    text-decoration: line-through;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.12em;
}

.pcs-woo-shop .pcs-product-card .price del .woocommerce-Price-amount {
    font-weight: 500;
}

.pcs-woo-shop .pcs-product-card .price ins {
    margin: 0;
    padding: 0;
    text-decoration: none;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--pcs-publishing-gold);
    background: none;
}

.pcs-woo-shop .pcs-product-card .price ins .woocommerce-Price-amount {
    font-weight: 600;
}

/* Archief: add-to-cart gebruikt .pcs-info-btn (distribution DNA) — volle kaartbreedte minus padding */
.pcs-woo-shop .pcs-product-card a.add_to_cart_button.pcs-info-btn {
    margin-top: auto;
    align-self: stretch;
    width: calc(100% - 2.2rem);
    max-width: none;
    margin-left: 1.1rem;
    margin-right: 1.1rem;
    margin-bottom: 1.15rem;
    box-sizing: border-box;
}

.pcs-woo-shop .pcs-product-card a.add_to_cart_button.pcs-info-btn.loading {
    opacity: 0.85;
    pointer-events: none;
}

/* —— Single product —— */
.pcs-woo-shop .single-product .product {
    position: relative;
    display: grid;
    gap: 2rem;
    align-items: start;
}

@media (min-width: 900px) {
    .pcs-woo-shop .single-product .product {
        grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    }
}

/*
 * Tabs + upsells + related zijn ook directe kinderen van .product. Zonder span vullen ze
 * automatisch de 2 kolommen (naast elkaar) — gerelateerde producten lijken dan «half breed» en ongestyled.
 */
.pcs-woo-shop.single-product .product > .woocommerce-tabs,
.pcs-woo-shop.single-product .product > .upsells.products,
.pcs-woo-shop.single-product .product > .related.products {
    grid-column: 1 / -1;
    width: 100%;
    min-width: 0;
}

/* Woo layout.css: clearfix op ul.products — op single-related worden ::before/::after grid-items (zie catalog-grid-bruteforce). */
.pcs-woo-shop.single-product .related.products ul.products::before,
.pcs-woo-shop.single-product .related.products ul.products::after,
.pcs-woo-shop.single-product .upsells.products ul.products::before,
.pcs-woo-shop.single-product .upsells.products ul.products::after {
    content: none !important;
    display: none !important;
}

.pcs-woo-shop .single-product div.images {
    background: rgba(12, 12, 12, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    padding: 1rem;
}

/* Desktop: iets meer lucht links → afbeelding visueel naar rechts t.o.v. de kolom */
@media (min-width: 900px) {
    .pcs-woo-shop .single-product div.images {
        padding-left: clamp(1.35rem, 2.75vw, 2.35rem);
        padding-right: 1rem;
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
}

.pcs-woo-shop .single-product .summary.entry-summary {
    background: rgba(12, 12, 12, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    padding: 1.5rem 1.75rem;
    backdrop-filter: blur(12px);
}

.pcs-woo-shop .single-product .product_title {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 0;
    font-size: clamp(1.75rem, 3vw, 2.5rem);
}

.pcs-woo-shop .single-product .woocommerce-product-details__short-description {
    color: var(--pcs-muted, rgba(242, 242, 242, 0.72));
}

.pcs-woo-shop .single-product .price {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--pcs-publishing-gold);
}

.pcs-woo-shop .single-product form.cart {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem 2.25rem;
    margin-top: 1.25rem;
    justify-content: flex-start;
    width: 100%;
    box-sizing: border-box;
}

/*
 * Quantity — zelfde op /cart (blok + klassiek) en single product:
 * donker vlak #0a0a0a, lichte rand, wit cijfer (zoals checkout-velden).
 */
.pcs-woo-shop .wc-block-components-quantity-selector {
    display: inline-flex !important;
    align-items: stretch;
    vertical-align: middle;
    border-radius: 9px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: #0a0a0a;
    box-sizing: border-box;
}

.pcs-woo-shop .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button {
    flex: 0 0 auto;
    min-width: 3rem;
    margin: 0 !important;
    padding: 0.5rem 0.75rem;
    border: none;
    border-radius: 0 !important;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(245, 245, 245, 0.96);
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    transition:
        background 0.2s ease,
        color 0.2s ease;
}

.pcs-woo-shop .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button:hover,
.pcs-woo-shop .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button:focus-visible {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    outline: none;
}

.pcs-woo-shop .wc-block-components-quantity-selector .wc-block-components-quantity-selector__input,
.pcs-woo-shop .wc-block-components-quantity-selector input[type="number"] {
    flex: 1 1 auto;
    min-width: 3rem;
    max-width: 5rem;
    margin: 0 !important;
    padding: 0.5rem 0.65rem !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    color: #fff !important;
    text-align: center !important;
    font-family: var(--pcs-font-body, "Poppins", system-ui, sans-serif) !important;
    font-weight: 600;
    font-size: 0.9375rem;
    line-height: 1.3;
    -moz-appearance: textfield;
    appearance: textfield;
}

.pcs-woo-shop .wc-block-components-quantity-selector input::-webkit-outer-spin-button,
.pcs-woo-shop .wc-block-components-quantity-selector input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Single product + winkelwagen (blok): overal dezelfde +/- — niet kleiner op desktop */
.pcs-woo-shop.single-product .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button,
.pcs-woo-shop.woocommerce-cart .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button {
    min-width: 3.35rem;
    padding: 0.55rem 0.85rem;
}

.pcs-woo-shop.single-product .wc-block-components-quantity-selector .wc-block-components-quantity-selector__input,
.pcs-woo-shop.single-product .wc-block-components-quantity-selector input[type="number"],
.pcs-woo-shop.woocommerce-cart .wc-block-components-quantity-selector .wc-block-components-quantity-selector__input,
.pcs-woo-shop.woocommerce-cart .wc-block-components-quantity-selector input[type="number"] {
    min-width: 3.25rem;
    padding: 0.55rem 0.85rem !important;
}

/* Klassiek Woo: wrapper + input (winkelwagen-tabel + productpagina) */
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity:not(.hidden),
.pcs-woo-shop .single-product form.cart .quantity:not(.hidden) {
    display: inline-flex;
    align-items: stretch;
    border-radius: 9px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: #0a0a0a;
    box-sizing: border-box;
}

/*
 * Single: chip naast skew-ATC — géén align-self: stretch (anders wordt de chip even hoog als
 * de knop en worden − / + / veld uitrekkend; winkelwagen-blok blijft compact).
 */
.pcs-woo-shop .single-product form.cart .quantity:not(.hidden) {
    flex: 0 0 auto;
    align-self: center;
    max-width: 100%;
}

/* Klassiek +/- (product + winkelwagen) — zelfde taal als wc-block knoppen */
.pcs-woo-shop .single-product form.cart .quantity .plus,
.pcs-woo-shop .single-product form.cart .quantity .minus,
.pcs-woo-shop .single-product form.cart .quantity a.plus,
.pcs-woo-shop .single-product form.cart .quantity a.minus,
.pcs-woo-shop .single-product form.cart .quantity button.plus,
.pcs-woo-shop .single-product form.cart .quantity button.minus,
.pcs-woo-shop .single-product form.cart .quantity > button[type="button"],
.pcs-woo-shop .single-product form.cart .quantity input[type="button"],
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .plus,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .minus,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity a.plus,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity a.minus,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity button.plus,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity button.minus,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity > button[type="button"],
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity input[type="button"] {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    box-sizing: border-box;
    min-width: 3.35rem;
    min-height: 2.75rem;
    margin: 0 !important;
    padding: 0.55rem 0.85rem;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: rgba(255, 255, 255, 0.06) !important;
    color: rgba(245, 245, 245, 0.96) !important;
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    text-decoration: none !important;
    transition:
        background 0.2s ease,
        color 0.2s ease;
}

.pcs-woo-shop .single-product form.cart .quantity .plus:hover,
.pcs-woo-shop .single-product form.cart .quantity .minus:hover,
.pcs-woo-shop .single-product form.cart .quantity a.plus:hover,
.pcs-woo-shop .single-product form.cart .quantity a.minus:hover,
.pcs-woo-shop .single-product form.cart .quantity button.plus:hover,
.pcs-woo-shop .single-product form.cart .quantity button.minus:hover,
.pcs-woo-shop .single-product form.cart .quantity > button[type="button"]:hover,
.pcs-woo-shop .single-product form.cart .quantity input[type="button"]:hover,
.pcs-woo-shop .single-product form.cart .quantity .plus:focus-visible,
.pcs-woo-shop .single-product form.cart .quantity .minus:focus-visible,
.pcs-woo-shop .single-product form.cart .quantity a.plus:focus-visible,
.pcs-woo-shop .single-product form.cart .quantity a.minus:focus-visible,
.pcs-woo-shop .single-product form.cart .quantity button.plus:focus-visible,
.pcs-woo-shop .single-product form.cart .quantity button.minus:focus-visible,
.pcs-woo-shop .single-product form.cart .quantity > button[type="button"]:focus-visible,
.pcs-woo-shop .single-product form.cart .quantity input[type="button"]:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .plus:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .minus:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity a.plus:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity a.minus:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity button.plus:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity button.minus:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity > button[type="button"]:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity input[type="button"]:hover,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .plus:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .minus:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity a.plus:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity a.minus:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity button.plus:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity button.minus:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity > button[type="button"]:focus-visible,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity input[type="button"]:focus-visible {
    background: rgba(255, 255, 255, 0.12) !important;
    color: #fff !important;
    outline: none;
}

.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .qty {
    flex: 1 1 auto;
    min-width: 2.75rem;
    width: auto !important;
    max-width: 5rem;
    margin: 0 !important;
    padding: 0.45rem 0.65rem !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    color: #fff !important;
    text-align: center;
    font-family: var(--pcs-font-body, "Poppins", system-ui, sans-serif);
    font-weight: 600;
    font-size: 0.9375rem;
    line-height: 1.3;
    -moz-appearance: textfield;
    appearance: textfield;
}

/* Single product: zelfde chip-dichtheid als wc-block quantity (ook op desktop) */
.pcs-woo-shop .single-product .quantity input.qty {
    flex: 1 1 auto;
    min-width: 3.25rem;
    width: auto !important;
    max-width: 5.5rem;
    margin: 0 !important;
    padding: 0.55rem 0.85rem !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    color: #fff !important;
    text-align: center;
    font-family: var(--pcs-font-body, "Poppins", system-ui, sans-serif);
    font-weight: 600;
    font-size: 0.9375rem;
    line-height: 1.3;
    -moz-appearance: textfield;
    appearance: textfield;
}

.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .qty::-webkit-outer-spin-button,
.pcs-woo-shop.woocommerce-cart .woocommerce .quantity .qty::-webkit-inner-spin-button,
.pcs-woo-shop .single-product .quantity input.qty::-webkit-outer-spin-button,
.pcs-woo-shop .single-product .quantity input.qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/*
 * Single ATC: win t.o.v. theme.json / .wp-element-button (paars).
 * Ook zónder .pcs-info-btn (footer-JS laadt laat of wijkt af) — daarom expliciet .wp-element-button + body …
 */
body.paperchase-shop-theme.pcs-woo-shop .single-product .woocommerce form.cart button.single_add_to_cart_button,
body.paperchase-shop-theme.pcs-woo-shop .single-product .woocommerce form.cart button.single_add_to_cart_button.wp-element-button,
body.paperchase-shop-theme.pcs-woo-shop .single-product form.cart button.single_add_to_cart_button,
body.paperchase-shop-theme.pcs-woo-shop .single-product .woocommerce form.cart .single_add_to_cart_button {
    -webkit-appearance: none !important;
    appearance: none !important;
    display: inline-block !important;
    margin-top: 0.25rem;
    width: auto;
    max-width: 22rem;
    padding: 0.62rem 0.85rem !important;
    box-sizing: border-box !important;
    background: var(--pcs-distribution-blue, #173cc8) !important;
    background-color: var(--pcs-distribution-blue, #173cc8) !important;
    background-image: none !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    border-bottom: 5px solid #fff !important;
    box-shadow: none !important;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.033em !important;
    font-size: clamp(0.68rem, 1.05vw, 0.78rem) !important;
    line-height: 1.2 !important;
    text-align: center !important;
    transform: skew(-10deg) !important;
    cursor: pointer !important;
    transition:
        background 0.25s ease,
        border-bottom-color 0.25s ease,
        color 0.25s ease !important;
}

body.paperchase-shop-theme.pcs-woo-shop .single-product .woocommerce form.cart button.single_add_to_cart_button:hover,
body.paperchase-shop-theme.pcs-woo-shop .single-product .woocommerce form.cart button.single_add_to_cart_button:focus-visible,
body.paperchase-shop-theme.pcs-woo-shop .single-product .woocommerce form.cart button.single_add_to_cart_button.wp-element-button:hover,
body.paperchase-shop-theme.pcs-woo-shop .single-product .woocommerce form.cart button.single_add_to_cart_button.wp-element-button:focus-visible,
body.paperchase-shop-theme.pcs-woo-shop .single-product form.cart button.single_add_to_cart_button:hover,
body.paperchase-shop-theme.pcs-woo-shop .single-product form.cart button.single_add_to_cart_button:focus-visible,
.pcs-woo-shop .single-product form.cart .single_add_to_cart_button.pcs-info-btn:hover,
.pcs-woo-shop .single-product form.cart .single_add_to_cart_button.pcs-info-btn:focus-visible {
    background: #1e4ae0 !important;
    background-color: #1e4ae0 !important;
    color: #fff !important;
    border-bottom-color: var(--pcs-publishing-gold, #ffcb00) !important;
}

/* Fallback zelfde specificiteit als .pcs-info-btn (distribution-ui) */
.pcs-woo-shop .single-product form.cart .single_add_to_cart_button.pcs-info-btn {
    margin-top: 0.25rem;
}

/* Blok-/FSE producttemplate: ATC knop heeft soms geen .single_add_to_cart_button */
body.paperchase-shop-theme.pcs-woo-shop .single-product button.wc-block-components-product-button__button,
body.paperchase-shop-theme.pcs-woo-shop .single-product .wp-block-add-to-cart-form button[type="submit"] {
    -webkit-appearance: none !important;
    appearance: none !important;
    background: var(--pcs-distribution-blue, #173cc8) !important;
    background-color: var(--pcs-distribution-blue, #173cc8) !important;
    background-image: none !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    border-bottom: 5px solid #fff !important;
    box-shadow: none !important;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.033em !important;
    font-size: clamp(0.68rem, 1.05vw, 0.78rem) !important;
    padding: 0.62rem 0.85rem !important;
    transform: skew(-10deg) !important;
}

body.paperchase-shop-theme.pcs-woo-shop .single-product button.wc-block-components-product-button__button:hover,
body.paperchase-shop-theme.pcs-woo-shop .single-product button.wc-block-components-product-button__button:focus-visible,
body.paperchase-shop-theme.pcs-woo-shop .single-product .wp-block-add-to-cart-form button[type="submit"]:hover,
body.paperchase-shop-theme.pcs-woo-shop .single-product .wp-block-add-to-cart-form button[type="submit"]:focus-visible {
    background: #1e4ae0 !important;
    background-color: #1e4ae0 !important;
    border-bottom-color: var(--pcs-publishing-gold, #ffcb00) !important;
    color: #fff !important;
}

.pcs-woo-shop .single-product .woocommerce button.button.alt:not(.pcs-info-btn) {
    background: color-mix(in srgb, var(--pcs-publishing-gold) 18%, transparent) !important;
    border: 1px solid color-mix(in srgb, var(--pcs-publishing-gold) 50%, transparent) !important;
    color: #fff !important;
    border-radius: 9px !important;
    font-weight: 700 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    padding: 0.85rem 1.5rem !important;
}

/* —— Product: reviews / «Beoordeel» (naam, e-mail, tekst) + submit als skew-CTA —— */
.pcs-woo-shop.single-product #review_form .comment-form,
.pcs-woo-shop.single-product #review_form #commentform {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.pcs-woo-shop.single-product #review_form .comment-form p,
.pcs-woo-shop.single-product #review_form #commentform p {
    margin: 0 0 0.85rem;
    float: none !important;
    width: 100% !important;
}

.pcs-woo-shop.single-product #review_form label {
    color: rgba(245, 245, 245, 0.94);
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    display: block;
    margin-bottom: 0.4rem;
}

.pcs-woo-shop.single-product #review_form .comment-form-author input,
.pcs-woo-shop.single-product #review_form .comment-form-email input,
.pcs-woo-shop.single-product #review_form .comment-form-comment textarea,
.pcs-woo-shop.single-product #review_form #author,
.pcs-woo-shop.single-product #review_form #email,
.pcs-woo-shop.single-product #review_form #comment {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    background: #0a0a0a !important;
    border: 1px solid color-mix(in srgb, var(--pcs-publishing-gold) 30%, transparent);
    border-radius: var(--pcs-radius-container, 9px);
    color: #fff !important;
    padding: 0.65rem 0.9rem;
    font-family: var(--pcs-font-body, "Poppins", system-ui, sans-serif);
    font-size: 0.9375rem;
    line-height: 1.45;
}

.pcs-woo-shop.single-product #review_form .comment-form-comment textarea,
.pcs-woo-shop.single-product #review_form #comment {
    min-height: 8rem;
    resize: vertical;
}

.pcs-woo-shop.single-product #review_form input::placeholder,
.pcs-woo-shop.single-product #review_form textarea::placeholder {
    color: rgba(255, 255, 255, 0.48);
    opacity: 1;
}

.pcs-woo-shop.single-product #review_form .comment-form-rating label,
.pcs-woo-shop.single-product #review_form .stars {
    margin-bottom: 0.35rem;
}

.pcs-woo-shop.single-product #review_form .form-submit,
.pcs-woo-shop.single-product #review_form p.form-submit {
    margin-top: 0.25rem;
    margin-bottom: 0;
    clear: both;
}

.pcs-woo-shop.single-product #review_form .form-submit input#submit,
.pcs-woo-shop.single-product #review_form input[type="submit"] {
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
    display: inline-block;
    width: auto;
    min-width: min(100%, 12rem);
    padding: 0.62rem 1.15rem;
    box-sizing: border-box;
    background: var(--pcs-distribution-blue, #173cc8) !important;
    background-image: none !important;
    color: #fff !important;
    border: none !important;
    border-bottom: 5px solid #fff !important;
    border-radius: 0 !important;
    transform: skew(-10deg);
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.033em !important;
    font-size: clamp(0.68rem, 1.05vw, 0.78rem) !important;
    line-height: 1.2 !important;
    box-shadow: none !important;
    transition:
        background 0.25s ease,
        border-bottom-color 0.25s ease;
}

.pcs-woo-shop.single-product #review_form .form-submit input#submit:hover,
.pcs-woo-shop.single-product #review_form input[type="submit"]:hover {
    background: #1e4ae0 !important;
    border-bottom-color: var(--pcs-publishing-gold, #ffcb00) !important;
    color: #fff !important;
}

/* Optioneel: Jetpack / CF7 onder product — zelfde velden + geen paarse wp-knop */
.pcs-woo-shop.single-product .wpcf7 input[type="text"],
.pcs-woo-shop.single-product .wpcf7 input[type="email"],
.pcs-woo-shop.single-product .wpcf7 textarea,
.pcs-woo-shop.single-product .wp-block-jetpack-contact-form .grunion-field-wrap input,
.pcs-woo-shop.single-product .wp-block-jetpack-contact-form .grunion-field-wrap textarea {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    background: #0a0a0a !important;
    border: 1px solid color-mix(in srgb, var(--pcs-publishing-gold) 30%, transparent);
    border-radius: var(--pcs-radius-container, 9px);
    color: #fff !important;
    padding: 0.65rem 0.9rem;
}

.pcs-woo-shop.single-product .wpcf7 input[type="submit"],
.pcs-woo-shop.single-product .wp-block-jetpack-contact-form button[type="submit"] {
    background: var(--pcs-distribution-blue, #173cc8) !important;
    background-image: none !important;
    color: #fff !important;
    border: none !important;
    border-bottom: 5px solid #fff !important;
    border-radius: 0 !important;
    transform: skew(-10deg);
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.033em !important;
    padding: 0.62rem 1.15rem !important;
    cursor: pointer;
    box-shadow: none !important;
}

.pcs-woo-shop .woocommerce-tabs,
.pcs-woo-shop .woocommerce-tabs ul.tabs {
    border-color: rgba(255, 255, 255, 0.1);
}

.pcs-woo-shop .woocommerce-tabs ul.tabs li a {
    color: var(--pcs-muted, rgba(242, 242, 242, 0.65));
    font-family: var(--pcs-font-display, "Jost", sans-serif);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.75rem;
}

.pcs-woo-shop .woocommerce-tabs ul.tabs li.active a {
    color: var(--pcs-publishing-gold);
}

/* Tabs + reviews: één duidelijk paneel (geen kale rand onder summary) */
.pcs-woo-shop.single-product .woocommerce-tabs {
    margin-top: 2rem;
    padding: 1.35rem 1.25rem 1.75rem;
    background: rgba(8, 8, 12, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 14px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.pcs-woo-shop.single-product .woocommerce-tabs .panel {
    margin: 0;
    padding-top: 1.25rem;
    color: rgba(235, 235, 235, 0.9);
    font-size: 0.9375rem;
    line-height: 1.65;
}

.pcs-woo-shop.single-product #reviews #comments > h2,
.pcs-woo-shop.single-product #reviews .woocommerce-Reviews-title {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-size: 1rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #fff;
    margin: 0 0 1rem;
}

.pcs-woo-shop.single-product #reviews .commentlist {
    list-style: none;
    margin: 0 0 1.25rem;
    padding: 0;
}

.pcs-woo-shop.single-product #reviews .comment-text {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    padding: 0.85rem 1rem;
}

.pcs-woo-shop.single-product #reviews .star-rating {
    color: var(--pcs-publishing-gold, #ffcb00);
}

.pcs-woo-shop.single-product #reply-title,
.pcs-woo-shop.single-product #reviews .comment-reply-title {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-size: 0.95rem;
    letter-spacing: 0.05em;
    color: #fff;
}

.pcs-woo-shop.single-product #reviews .comment-notes {
    color: rgba(220, 220, 220, 0.72);
    font-size: 0.8125rem;
}

/* SKU / categorie onder prijs */
.pcs-woo-shop.single-product .product_meta {
    margin-top: 1.35rem;
    padding-top: 1.1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 0.8125rem;
    line-height: 1.7;
    color: rgba(210, 210, 210, 0.78);
}

.pcs-woo-shop.single-product .product_meta > span {
    display: block;
    margin-bottom: 0.35rem;
}

.pcs-woo-shop.single-product .product_meta a {
    color: var(--pcs-publishing-gold, #ffcb00);
    text-decoration: none;
}

.pcs-woo-shop.single-product .product_meta a:hover {
    text-decoration: underline;
}

/* Gerelateerde + upsell: zelfde visuele taal als shop-grid */
.pcs-woo-shop.single-product .related.products,
.pcs-woo-shop.single-product .upsells.products {
    margin-top: 2.75rem;
    padding-top: 2.25rem;
    padding-bottom: 0.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    clear: both;
    width: 100%;
}

.pcs-woo-shop.single-product .related.products > h2,
.pcs-woo-shop.single-product .upsells.products > h2 {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-weight: 600;
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #fff;
    text-align: center;
    margin: 0 0 1.75rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.pcs-woo-shop.single-product .related.products ul.products,
.pcs-woo-shop.single-product .upsells.products ul.products {
    margin-bottom: 0 !important;
}

/*
 * Gerelateerde / upsell: op desktop voldoende kaartbreedte (theme zette columns op 2 in PHP;
 * extra gap iets ruimer dan standaard shop-grid).
 */
@media (min-width: 900px) {
    .pcs-woo-shop.single-product .related.products ul.products,
    .pcs-woo-shop.single-product .upsells.products ul.products {
        gap: clamp(1rem, 1.8vw, 1.65rem);
        row-gap: clamp(1.1rem, 1.9vw, 1.75rem);
        column-gap: clamp(1rem, 1.8vw, 1.65rem);
    }
}

/* Onderkant pagina: lucht vóór footer + wrapper */
.pcs-woo-shop.single-product .site-main {
    padding-bottom: clamp(3rem, 6vw, 5rem);
}

.pcs-woo-shop.single-product .pcs-woo-wrap {
    padding-bottom: clamp(2.5rem, 5vw, 4.5rem);
}

/* —— Cart & tables —— */
.pcs-woo-shop .woocommerce table.shop_table {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    overflow: hidden;
    background: rgba(10, 10, 10, 0.6);
}

.pcs-woo-shop .woocommerce table.shop_table th,
.pcs-woo-shop .woocommerce table.shop_table td {
    border-color: rgba(255, 255, 255, 0.08);
    padding: 0.85rem 1rem;
    color: rgba(245, 245, 245, 0.96);
}

/* Klassieke winkelwagen: leesbare productregels (desktop + mobiel) */
.pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table .product-name a:not(.remove) {
    color: #fff !important;
    font-weight: 600;
    text-decoration: none;
}

.pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table .product-name a:not(.remove):hover {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

.pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table .product-price,
.pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table .product-subtotal,
.pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table td.product-total {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
    font-weight: 600;
}

.pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table th {
    color: rgba(255, 255, 255, 0.88);
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table dl.variation {
    color: rgba(200, 200, 200, 0.85);
    font-size: 0.8125rem;
}

.pcs-woo-shop .woocommerce a.remove {
    color: var(--pcs-bookings-red) !important;
}

.pcs-woo-shop .woocommerce .cart-collaterals .cart_totals {
    background: rgba(12, 12, 12, 0.72);
    border: 1px solid color-mix(in srgb, var(--pcs-publishing-gold) 20%, transparent);
    border-radius: 14px;
    padding: 1.25rem;
    color: rgba(245, 245, 245, 0.95);
}

.pcs-woo-shop .woocommerce .cart-collaterals .cart_totals th,
.pcs-woo-shop .woocommerce .cart-collaterals .cart_totals td {
    color: inherit;
}

.pcs-woo-shop .woocommerce .cart-collaterals .cart_totals .order-total th,
.pcs-woo-shop .woocommerce .cart-collaterals .cart_totals .order-total td {
    color: var(--pcs-publishing-gold, #ffcb00);
    font-weight: 700;
}

.pcs-woo-shop.woocommerce-cart .entry-title,
.pcs-woo-shop.woocommerce-cart h1.woocommerce-cart-form__cart-title,
.pcs-woo-shop.woocommerce-cart .woocommerce > h1 {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    color: #fff;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* Mobiel: responsieve tabel — label voor cel leesbaar; prijzen blijven binnen het kader */
@media (max-width: 768px) {
    .pcs-woo-shop.woocommerce-cart .woocommerce-cart-form {
        max-width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior-x: contain;
    }

    /* Overschrijf globale overflow:hidden op .shop_table — voorkomt dat (sub)totalen visueel worden afgesneden */
    .pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table.shop_table_responsive {
        width: 100%;
        min-width: 0;
        overflow: visible;
    }

    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td {
        text-align: right !important;
        color: rgba(245, 245, 245, 0.96) !important;
        box-sizing: border-box;
        max-width: 100%;
        overflow-wrap: anywhere;
        word-break: break-word;
        hyphens: auto;
    }

    /* Prijs / subtotaal: compactere cijfers op smalle schermen */
    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td.product-price,
    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td.product-subtotal,
    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td.product-total {
        font-size: 0.8125rem;
        letter-spacing: 0.02em;
    }

    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td::before {
        color: rgba(255, 255, 255, 0.72) !important;
        font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
        font-size: 0.65rem;
        letter-spacing: 0.07em;
        text-transform: uppercase;
        max-width: min(48%, 11rem);
        overflow-wrap: anywhere;
    }

    .pcs-woo-shop.woocommerce-cart .woocommerce .cart-collaterals .cart_totals table.shop_table_responsive tbody tr td {
        overflow-wrap: anywhere;
        word-break: break-word;
        box-sizing: border-box;
    }
}

@media (max-width: 420px) {
    .pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table th,
    .pcs-woo-shop.woocommerce-cart .woocommerce table.shop_table td {
        padding: 0.6rem 0.5rem;
    }

    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td.product-price,
    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td.product-subtotal,
    .pcs-woo-shop.woocommerce-cart table.shop_table_responsive tbody tr td.product-total {
        font-size: 0.75rem;
    }
}

/* Cart: doorgaan naar afrekenen — zelfde skew-blauw als hub */
.pcs-woo-shop .woocommerce .wc-proceed-to-checkout a.checkout-button {
    position: relative;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 22rem;
    margin-inline: auto;
    padding: 0.62rem 0.85rem !important;
    box-sizing: border-box;
    background: var(--pcs-distribution-blue, #173cc8) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    border-bottom: 5px solid #fff !important;
    transform: skew(-10deg);
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif) !important;
    font-weight: 600 !important;
    letter-spacing: 0.033em !important;
    text-transform: uppercase !important;
    font-size: clamp(0.68rem, 1.05vw, 0.78rem) !important;
    line-height: 1.2 !important;
    transition:
        background 0.25s ease,
        border-bottom-color 0.25s ease !important;
}

.pcs-woo-shop .woocommerce .wc-proceed-to-checkout a.checkout-button:hover {
    background: #1e4ae0 !important;
    border-bottom-color: var(--pcs-publishing-gold, #ffcb00) !important;
    color: #fff !important;
}

/* —— Checkout (classic + blocks) —— */
.pcs-woo-shop .woocommerce-checkout #customer_details .col-1,
.pcs-woo-shop .woocommerce-checkout #customer_details .col-2 {
    background: rgba(12, 12, 12, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 14px;
    padding: 1.25rem;
    margin-bottom: 1rem;
}

.pcs-woo-shop .woocommerce form .form-row input.input-text,
.pcs-woo-shop .woocommerce form .form-row textarea,
.pcs-woo-shop .woocommerce form .form-row select {
    background: #0a0a0a;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 9px;
    color: #fff;
    padding: 0.6rem 0.75rem;
    color-scheme: dark;
}

.pcs-woo-shop.woocommerce-checkout .woocommerce form .form-row select option {
    background-color: #0a0a0a;
    color: #fff;
}

.pcs-woo-shop .woocommerce form .form-row input.input-text::placeholder,
.pcs-woo-shop .woocommerce form .form-row textarea::placeholder {
    color: rgba(255, 255, 255, 0.5);
    opacity: 1;
}

.pcs-woo-shop .woocommerce-checkout .form-row label,
.pcs-woo-shop .woocommerce-checkout .woocommerce-billing-fields__field-wrapper > p > label,
.pcs-woo-shop .woocommerce-checkout .woocommerce-additional-fields__field-wrapper > p > label,
.pcs-woo-shop .woocommerce-checkout #order_review_heading {
    color: rgba(245, 245, 245, 0.95);
}

/*
 * WC Blocks — checkout:
 * Niet één globale #1a1a1a op .wc-block-checkout: die erfde naar tekst buiten de lichte kolommen
 * en viel weg op de donkere site-achtergrond (#131313).
 * → Lichte defaults op de wrapper; donkere kopie alleen op main/sidebar (Woo-“cartons”).
 */
.pcs-woo-shop .wc-block-checkout {
    color: rgba(242, 242, 242, 0.94);
}

/*
 * Main/sidebar: geen donkere erfkleur op transparante/donkere kolommen (dan #1a1a1a op #131313).
 * Zelfde logica als winkelwagen-blok: lichte tekst; witte “carton”-vlakken krijgen eigen regels.
 */
.pcs-woo-shop .wc-block-checkout .wc-block-checkout__main,
.pcs-woo-shop .wc-block-checkout .wc-block-checkout__sidebar {
    color: rgba(242, 242, 242, 0.96);
}

/* Voorkom dat dropdowns/poplegels onderaan checkout worden afgekapt */
.pcs-woo-shop.woocommerce-checkout .wc-block-checkout,
.pcs-woo-shop.woocommerce-checkout .wc-block-checkout__main,
.pcs-woo-shop.woocommerce-checkout .wc-block-components-sidebar-layout,
.pcs-woo-shop.woocommerce-checkout .wc-block-components-form,
.pcs-woo-shop.woocommerce-checkout .wc-block-components-checkout-step {
    overflow: visible;
}

/* Onderaan checkout: ruimte vóór footer i.v.m. CookieAdmin + eventuele vaste Woo-actie op mobiel */
.pcs-woo-shop.woocommerce-checkout .site-main {
    padding-bottom: clamp(4rem, 10vw, 7rem);
}

@media (max-width: 782px) {
    .pcs-woo-shop.woocommerce-checkout .site-main {
        padding-bottom: calc(6.5rem + env(safe-area-inset-bottom, 0px));
    }

    body.woocommerce-checkout.paperchase-shop-theme:has(.cookieadmin_re_consent) .pcs-woo-shop.woocommerce-checkout .site-main,
    body.woocommerce-checkout.paperchase-shop-theme:has(.cookieadmin_re_consent) .site-main {
        padding-bottom: calc(10.5rem + env(safe-area-inset-bottom, 0px));
    }
}

/*
 * Voorwaarden / toestemming: zelfde retail-donkere kaart als overige checkout-velden (#0a0a0a + witte tekst).
 * (Eerder wit vlak + #141414 botste met theme.json / blokken → onleesbare «By proceeding…»-tekst.)
 */
.pcs-woo-shop .wc-block-checkout .wc-block-checkout__terms,
.pcs-woo-shop .wc-block-checkout .wc-block-checkout__terms p,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-terms-block,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-terms-block"],
.pcs-woo-shop .wc-block-checkout .woocommerce-terms-and-conditions-wrapper {
    background: #0a0a0a !important;
    background-color: #0a0a0a !important;
    color: rgba(255, 255, 255, 0.94) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 12px !important;
    padding: 1rem 1.15rem !important;
    color-scheme: dark !important;
}

.pcs-woo-shop .wc-block-checkout .wc-block-checkout__terms a,
.pcs-woo-shop .wc-block-checkout .woocommerce-terms-and-conditions-wrapper a,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-terms-block"] a {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
    text-decoration: underline;
    text-underline-offset: 0.12em;
    font-weight: 600;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-checkout-return-to-cart-button {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

/*
 * Betaling: zelfde lichte tekst als rest checkout (geen #141414 op donkere achtergrond).
 * Panelen met licht vlak van Woo krijgen desnoods eigen achtergrond via blok-CSS.
 */
.pcs-woo-shop .wc-block-checkout .wc-block-components-payment-method .wc-block-components-radio-control__label {
    color: rgba(245, 245, 245, 0.96) !important;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-payment-method-description,
.pcs-woo-shop .wc-block-checkout .wc-block-components-payment-method__description {
    color: rgba(220, 220, 220, 0.9) !important;
}

/* Klassiek afrekenen: betaalblok onderaan */
.pcs-woo-shop.woocommerce-checkout #payment {
    background: rgba(12, 12, 12, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 14px;
    padding: 1.15rem 1.25rem;
    color: rgba(245, 245, 245, 0.95);
}

.pcs-woo-shop.woocommerce-checkout #payment .payment_methods li label,
.pcs-woo-shop.woocommerce-checkout #payment .payment_box {
    color: rgba(245, 245, 245, 0.92);
}

.pcs-woo-shop.woocommerce-checkout #payment .payment_box {
    background: rgba(0, 0, 0, 0.35);
    border-radius: 8px;
}

.pcs-woo-shop .wc-block-cart {
    color: rgba(245, 245, 245, 0.96);
}

.pcs-woo-shop.woocommerce-cart .wc-block-cart {
    background: rgba(8, 8, 12, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 14px;
    padding: 1.25rem clamp(0.5rem, 3vw, 1.35rem) 1.5rem;
    max-width: 100%;
    box-sizing: border-box;
    min-width: 0;
}

/* WC Blocks winkelwagen: prijskolommen mogen krimpen op smalle telefoons */
@media (max-width: 600px) {
    .pcs-woo-shop.woocommerce-cart .wc-block-cart {
        padding-left: max(0.5rem, env(safe-area-inset-left, 0));
        padding-right: max(0.5rem, env(safe-area-inset-right, 0));
    }

    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-cart-items,
    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-cart__main {
        max-width: 100%;
        min-width: 0;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-cart-items__row,
    .pcs-woo-shop.woocommerce-cart .wc-block-cart tr.wc-block-cart-items__row {
        min-width: 0;
        max-width: 100%;
    }

    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-cart-item__prices,
    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-components-product-price,
    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-cart-item__total,
    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-components-totals-item__value {
        min-width: 0 !important;
        max-width: 100%;
        overflow-wrap: anywhere;
        word-break: break-word;
        text-align: end;
    }

    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-components-totals-item {
        min-width: 0;
        max-width: 100%;
        flex-wrap: wrap;
        gap: 0.15rem 0.5rem;
    }

    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-components-totals-footer-item,
    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wp-block-woocommerce-cart-order-summary-block {
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
}

@media (max-width: 420px) {
    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-components-product-price,
    .pcs-woo-shop.woocommerce-cart .wc-block-cart .wc-block-cart-item__prices {
        font-size: 0.8125rem;
    }
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-form .wc-block-components-text-input label,
.pcs-woo-shop .wc-block-checkout .wc-block-components-text-input label,
.pcs-woo-shop .wc-block-checkout .wc-block-components-select-wrapper label,
.pcs-woo-shop .wc-block-checkout .wc-block-components-checkbox__label,
.pcs-woo-shop .wc-block-checkout .wc-block-components-radio-control__option,
.pcs-woo-shop .wc-block-checkout .wc-block-components-title,
.pcs-woo-shop .wc-block-checkout .wc-block-components-title .wc-block-components-title__text,
.pcs-woo-shop .wc-block-checkout .wc-block-components-checkout-step__title,
.pcs-woo-shop .wc-block-checkout .wc-block-components-checkout-step__description,
.pcs-woo-shop .wc-block-checkout .wc-block-components-form-row-description,
.pcs-woo-shop .wc-block-checkout .wc-block-components-product-metadata__description {
    color: rgba(245, 245, 245, 0.96) !important;
}

/*
 * Checkout order note (blok): op donkere achtergrond waren #0f0f0f-labels onleesbaar.
 * Align met classic checkout: lichte labels + donkere velden (#0a0a0a), witte tekst.
 */
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] {
    color: rgba(245, 245, 245, 0.96) !important;
}

.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-checkout-step__title,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-checkout-step__description,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-text-input label,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-select-wrapper label,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-checkbox__label,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-form-row-description,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-title,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-title .wc-block-components-title__text,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-checkout-step__title,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-checkout-step__description,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-text-input label,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-select-wrapper label,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-checkbox__label,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-form-row-description,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-title,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-title .wc-block-components-title__text {
    color: rgba(245, 245, 245, 0.96) !important;
}

.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-text-input input[type="email"],
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-text-input input[type="text"],
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-text-input input[type="tel"],
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-text-input input[type="number"],
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-text-input input[type="password"],
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-text-input input[type="url"],
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-textarea textarea,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-combobox .wc-block-components-combobox-control__input,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-select .wc-block-components-select__container select,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-select select,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-text-input input[type="email"],
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-text-input input[type="text"],
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-text-input input[type="tel"],
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-text-input input[type="number"],
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-text-input input[type="password"],
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-text-input input[type="url"],
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-textarea textarea,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-combobox .wc-block-components-combobox-control__input,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-select .wc-block-components-select__container select,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-select select {
    color: #fff !important;
    background-color: #0a0a0a !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 9px !important;
}

.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block .wc-block-components-textarea textarea,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] .wc-block-components-textarea textarea {
    min-height: 6.5rem;
    padding: 0.65rem 0.75rem !important;
}

.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block input::placeholder,
.pcs-woo-shop .wc-block-checkout .wp-block-woocommerce-checkout-order-note-block textarea::placeholder,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] input::placeholder,
.pcs-woo-shop .wc-block-checkout [data-block-name="woocommerce/checkout-order-note-block"] textarea::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
    opacity: 1 !important;
}

/* Winkelwagen (blok): labels en titels licht — niet 1:1 checkout-panel */
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input label,
.pcs-woo-shop .wc-block-cart .wc-block-components-select-wrapper label,
.pcs-woo-shop .wc-block-cart .wc-block-components-checkbox__label,
.pcs-woo-shop .wc-block-cart .wc-block-components-title,
.pcs-woo-shop .wc-block-cart .wc-block-components-title .wc-block-components-title__text {
    color: rgba(238, 238, 238, 0.95) !important;
}

/* Alleen winkelwagen-blok: lichte “carton”-velden (wit + donkere tekst) */
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input input[type="email"],
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input input[type="text"],
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input input[type="tel"],
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input input[type="number"],
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input input[type="password"],
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input input[type="url"],
.pcs-woo-shop .wc-block-cart .wc-block-components-textarea textarea,
.pcs-woo-shop .wc-block-cart .wc-block-components-combobox .wc-block-components-combobox-control__input,
.pcs-woo-shop .wc-block-cart .wc-block-components-select .wc-block-components-select__container select,
.pcs-woo-shop .wc-block-cart .wc-block-components-select select {
    color: #111 !important;
    background-color: #fff !important;
    border-color: rgba(0, 0, 0, 0.18) !important;
}

/*
 * Checkout (blok): één donker-veld-stijl op hele formulier — zelfde als klassiek #customer_details / order note.
 * (Eerder golden witte inputs + #111 hierdoor onleesbaar op donkere site-achtergrond.)
 */
.pcs-woo-shop .wc-block-checkout .wc-block-components-text-input input[type="email"],
.pcs-woo-shop .wc-block-checkout .wc-block-components-text-input input[type="text"],
.pcs-woo-shop .wc-block-checkout .wc-block-components-text-input input[type="tel"],
.pcs-woo-shop .wc-block-checkout .wc-block-components-text-input input[type="number"],
.pcs-woo-shop .wc-block-checkout .wc-block-components-text-input input[type="password"],
.pcs-woo-shop .wc-block-checkout .wc-block-components-text-input input[type="url"],
.pcs-woo-shop .wc-block-checkout .wc-block-components-textarea textarea,
.pcs-woo-shop .wc-block-checkout .wc-block-components-combobox .wc-block-components-combobox-control__input,
.pcs-woo-shop .wc-block-checkout .wc-block-components-select .wc-block-components-select__container select,
.pcs-woo-shop .wc-block-checkout .wc-block-components-select select {
    color: #fff !important;
    background-color: #0a0a0a !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 9px !important;
    color-scheme: dark !important;
}

.pcs-woo-shop.woocommerce-checkout .wc-block-checkout .wc-block-components-select .wc-block-components-select__container,
.pcs-woo-shop.woocommerce-checkout .wc-block-checkout .wc-block-components-combobox-control {
    background-color: #0a0a0a !important;
    border-radius: 9px !important;
}

.pcs-woo-shop .wc-block-checkout input::placeholder,
.pcs-woo-shop .wc-block-checkout textarea::placeholder {
    color: rgba(255, 255, 255, 0.52) !important;
    opacity: 1 !important;
}

.pcs-woo-shop .wc-block-cart input::placeholder,
.pcs-woo-shop .wc-block-cart textarea::placeholder,
.pcs-woo-shop .wc-block-cart .wc-block-components-text-input input::placeholder,
.pcs-woo-shop .wc-block-cart .wc-block-components-textarea textarea::placeholder {
    color: #333 !important;
    opacity: 1 !important;
}

/* Checkout orderoverzicht: zelfde contrast als winkelwagen (donkere achtergrond site) */
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary .wc-block-components-product-name,
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-product-name,
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary .wc-block-components-product-metadata,
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item .wc-block-components-product-metadata {
    color: rgba(248, 248, 248, 0.96) !important;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-totals-item__label,
.pcs-woo-shop .wc-block-checkout .wc-block-checkout__sidebar .wc-block-components-totals-item__label {
    color: rgba(248, 248, 248, 0.92) !important;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-totals-item__value,
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__individual-prices,
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__total-price {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

/*
 * Checkout order summary: productnaam en bedrag op één regel (niet prijs onder de titel).
 * Flex + order: past verschillende Woo DOM-volgordes (naam / meta / prijs).
 */
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: flex-start !important;
    gap: 0.65rem;
    width: 100%;
    box-sizing: border-box;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__image {
    flex: 0 0 auto;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description {
    flex: 1 1 minmax(0, 1fr);
    min-width: 0;
    display: flex !important;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: baseline;
    column-gap: 0.65rem;
    row-gap: 0.25rem;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-product-name {
    order: 1;
    flex: 1 1 0;
    margin: 0 !important;
    min-width: 0;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-order-summary-item__individual-prices,
.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-order-summary-item__total-price {
    order: 2;
    flex: 0 0 auto;
    margin-left: auto !important;
    text-align: right !important;
    white-space: nowrap;
}

.pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-product-metadata {
    order: 3;
    flex: 1 0 100%;
    width: 100%;
    min-width: 0;
}

@media (max-width: 420px) {
    .pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-order-summary-item__individual-prices,
    .pcs-woo-shop .wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-order-summary-item__total-price {
        white-space: normal;
        max-width: 42%;
        overflow-wrap: anywhere;
    }
}

/* Klassiek checkout: order review tabel — prijskolom top uitgelijnd */
.pcs-woo-shop.woocommerce-checkout .woocommerce-checkout-review-order-table .product-name {
    vertical-align: top;
}

.pcs-woo-shop.woocommerce-checkout .woocommerce-checkout-review-order-table .product-total {
    vertical-align: top;
    text-align: right;
    white-space: nowrap;
}

/* Winkelwagen: regels + totalen op donker */
.pcs-woo-shop .wc-block-cart .wc-block-cart-items__row,
.pcs-woo-shop .wc-block-cart .wp-block-woocommerce-cart-line-items-block,
.pcs-woo-shop .wc-block-cart .wc-block-components-product-name,
.pcs-woo-shop .wc-block-cart .wc-block-cart-item__prices,
.pcs-woo-shop .wc-block-cart .wc-block-components-product-price,
.pcs-woo-shop .wc-block-cart .wc-block-components-totals-item__label,
.pcs-woo-shop .wc-block-cart .wc-block-components-totals-item__value,
.pcs-woo-shop .wc-block-cart .wc-block-components-product-metadata {
    color: rgba(248, 248, 248, 0.96) !important;
}

.pcs-woo-shop .wc-block-cart .wc-block-components-product-price,
.pcs-woo-shop .wc-block-cart .wc-block-cart-item__prices .price,
.pcs-woo-shop .wc-block-cart .wc-block-components-totals-item__value {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

/* Lege winkelwagen + «New in store» (donkere achtergrond site) */
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block h1,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block h2,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block p,
.pcs-woo-shop .wc-block-cart__empty-cart__title {
    color: rgba(242, 242, 242, 0.96) !important;
}

/*
 * Cart-pagina (blokken): paginatitel + lege-mand + «New in store» als één retail-flow
 * (zelfde typografie/spacing als shop — zie .woocommerce-products-header__title).
 */
body.woocommerce-cart.pcs-woo-shop .entry-header {
    margin-bottom: 1.25rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

body.woocommerce-cart.pcs-woo-shop .entry-header .entry-title {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    line-height: 1.15;
    margin: 0;
    color: #fff;
}

/*
 * Lege mand: duidelijke «kaart» + «New in store» als raster (legacy grid én Product Collection).
 */
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block {
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
    padding: clamp(1.25rem, 3vw, 2rem);
    max-width: min(56rem, 100%);
    box-sizing: border-box;
    background: rgba(8, 8, 12, 0.58);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.35);
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-cart__empty-cart__title,
body.woocommerce-cart.pcs-woo-shop .wc-block-cart__empty-cart__title {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: clamp(1rem, 2.2vw, 1.2rem) !important;
    margin: 0 0 1.25rem !important;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.94) !important;
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wp-block-separator,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block hr {
    border: none;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    margin: 1.5rem 0;
}

/* «New in store»: legacy grid + Product Collection (wc-block-product-template) — geen kale bullet-lijst */
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-grid__products,
body.woocommerce-cart.pcs-woo-shop .wp-block-product-new .wc-block-grid__products,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block ul.wc-block-grid__products,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block ul.wc-block-product-template,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block ol.wc-block-product-template,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wp-block-woocommerce-product-collection ul.wc-block-product-template {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 11rem), 1fr)) !important;
    gap: clamp(0.75rem, 2.2vw, 1.25rem) !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-grid__product,
body.woocommerce-cart.pcs-woo-shop .wp-block-product-new .wc-block-grid__product,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block li.wc-block-product {
    min-width: 0;
    width: auto !important;
    max-width: none !important;
    background: rgba(12, 12, 12, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    padding: 0.75rem !important;
    box-sizing: border-box;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem;
    height: 100%;
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-components-product-image,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-grid__product-image {
    border-radius: 10px;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.35);
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-components-product-image img,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-grid__product img {
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    display: block !important;
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block h2:not(.wc-block-cart__empty-cart__title),
body.woocommerce-cart.pcs-woo-shop .wp-block-product-new > h2 {
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif);
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-size: clamp(1.1rem, 2.2vw, 1.35rem);
    margin: 1.75rem 0 1rem;
    padding-top: 0.25rem;
    color: rgba(255, 255, 255, 0.96) !important;
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-product .wc-block-components-product-name,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-product .wc-block-components-product-name a,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-product .wp-block-post-title a {
    color: #fff !important;
}

body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-product .wc-block-components-product-price,
body.woocommerce-cart.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-product .price {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

.pcs-woo-shop .wc-block-cart .wc-block-grid__product-title a,
.pcs-woo-shop .wc-block-cart .wc-block-grid__product-title,
.pcs-woo-shop .wp-block-product-new .wc-block-grid__product-title a,
.pcs-woo-shop .wp-block-woocommerce-product-collection .wc-block-product .wc-block-grid__product-title {
    color: #fff !important;
}

.pcs-woo-shop .wc-block-cart .wc-block-grid__product-price,
.pcs-woo-shop .wp-block-product-new .wc-block-grid__product-price,
.pcs-woo-shop .wp-block-woocommerce-product-collection .wc-block-product .wc-block-grid__product-price {
    color: var(--pcs-publishing-gold, #ffcb00) !important;
}

/*
 * Cart/checkout: coupon e.d. — goud-tint (niet productraster).
 * Let op: +/- quantity gebruikt óók .wc-block-components-button — die uitsluiten (anders wint
 * deze regel t.o.v. .wc-block-components-quantity-selector__button en breekt chip/interactie).
 */
.pcs-woo-shop .wc-block-cart .wc-block-components-button:not(.is-link):not(.wc-block-components-quantity-selector__button),
.pcs-woo-shop .wc-block-checkout .wc-block-components-button:not(.is-link):not(.wc-block-components-quantity-selector__button) {
    background: color-mix(in srgb, var(--pcs-publishing-gold) 20%, transparent) !important;
    border: 1px solid color-mix(in srgb, var(--pcs-publishing-gold) 45%, transparent) !important;
    color: #fff !important;
    border-radius: 9px !important;
}

/* Producttegels (grid / collection / lege winkelwagen): zelfde distribution-DNA als .pcs-info-btn */
.pcs-woo-shop .wc-block-grid .wc-block-grid__product .wc-block-components-button:not(.is-link),
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-button:not(.is-link),
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-components-button:not(.is-link),
.pcs-woo-shop .wc-block-grid .wc-block-grid__product .wp-block-button__link,
.pcs-woo-shop ul.wc-block-product-template .wp-block-button__link,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wp-block-button__link {
    background: var(--pcs-distribution-blue, #173cc8) !important;
    background-image: none !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    border-bottom: 5px solid #fff !important;
    box-shadow: none !important;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.033em !important;
    font-size: clamp(0.68rem, 1.05vw, 0.78rem) !important;
    line-height: 1.2 !important;
    transform: skew(-10deg);
    padding: 0.62rem 0.85rem !important;
    text-align: center;
    transition:
        background 0.25s ease,
        border-bottom-color 0.25s ease;
}

.pcs-woo-shop .wc-block-grid .wc-block-grid__product .wc-block-components-button:not(.is-link):hover,
.pcs-woo-shop .wc-block-grid .wc-block-grid__product .wc-block-components-button:not(.is-link):focus-visible,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-button:not(.is-link):hover,
.pcs-woo-shop ul.wc-block-product-template .wc-block-components-button:not(.is-link):focus-visible,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-components-button:not(.is-link):hover,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wc-block-components-button:not(.is-link):focus-visible,
.pcs-woo-shop .wc-block-grid .wc-block-grid__product .wp-block-button__link:hover,
.pcs-woo-shop .wc-block-grid .wc-block-grid__product .wp-block-button__link:focus-visible,
.pcs-woo-shop ul.wc-block-product-template .wp-block-button__link:hover,
.pcs-woo-shop ul.wc-block-product-template .wp-block-button__link:focus-visible,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wp-block-button__link:hover,
.pcs-woo-shop .wp-block-woocommerce-empty-cart-block .wp-block-button__link:focus-visible {
    background: #1e4ae0 !important;
    color: #fff !important;
    border-bottom-color: var(--pcs-publishing-gold, #ffcb00) !important;
}

/*
 * Fallback: overige .wc-block-components-button — quantity +/- uitsluiten (zelfde specificiteit
 * als chip-regels hierboven; zonder :not() overschrijft deze regel later de +/- knoppen).
 */
.pcs-woo-shop .wc-block-components-button:not(.is-link):not(.wc-block-components-quantity-selector__button) {
    background: color-mix(in srgb, var(--pcs-publishing-gold) 20%, transparent) !important;
    border: 1px solid color-mix(in srgb, var(--pcs-publishing-gold) 45%, transparent) !important;
    color: #fff !important;
    border-radius: 9px !important;
}

/* —— Account —— */
.pcs-woo-shop .woocommerce-MyAccount-navigation {
    background: rgba(12, 12, 12, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 0.5rem 0;
}

.pcs-woo-shop .woocommerce-MyAccount-navigation ul {
    gap: 0;
}

.pcs-woo-shop .woocommerce-MyAccount-navigation-link a {
    color: var(--pcs-muted, rgba(242, 242, 242, 0.7));
    padding: 0.65rem 1.25rem;
    display: block;
}

.pcs-woo-shop .woocommerce-MyAccount-navigation-link.is-active a {
    color: var(--pcs-publishing-gold);
    background: color-mix(in srgb, var(--pcs-publishing-gold) 8%, transparent);
}

/* —— Notices —— */
body.paperchase-shop-theme .woocommerce-notices-wrapper:first-child,
.pcs-woo-shop .woocommerce-notices-wrapper:first-child {
    margin-bottom: 1.25rem;
}

body.paperchase-shop-theme .woocommerce-message,
body.paperchase-shop-theme .woocommerce-info,
.pcs-woo-shop .woocommerce-message,
.pcs-woo-shop .woocommerce-info {
    background: color-mix(in srgb, var(--pcs-distribution-blue) 15%, transparent);
    border: 1px solid color-mix(in srgb, var(--pcs-distribution-blue) 35%, transparent);
    border-radius: 9px;
    color: #e8e8e8;
    padding: 1rem 1.1rem;
    line-height: 1.45;
}

body.paperchase-shop-theme .woocommerce-error,
.pcs-woo-shop .woocommerce-error {
    background: color-mix(in srgb, var(--pcs-bookings-red) 15%, transparent);
    border: 1px solid color-mix(in srgb, var(--pcs-bookings-red) 45%, transparent);
    border-radius: 9px;
}

/*
 * «View cart» na add-to-cart:
 * - Shop/archief (AJAX): <a class="added_to_cart wc-forward"> in productkaart — géén .woocommerce-message
 * - Klassiek: .woocommerce-message a.button.wc-forward
 * - Blocks store notice: .wc-block-components-notice-banner__content .wc-forward
 */
body.paperchase-shop-theme a.added_to_cart.wc-forward,
body.pcs-woo-shop a.added_to_cart.wc-forward,
body.paperchase-shop-theme ul.products li.product a.added_to_cart.wc-forward,
body.pcs-woo-shop ul.products li.product a.added_to_cart.wc-forward,
body.paperchase-shop-theme .pcs-product-card a.added_to_cart.wc-forward,
body.pcs-woo-shop .pcs-product-card a.added_to_cart.wc-forward,
body.paperchase-shop-theme .woocommerce-notices-wrapper a.wc-forward,
body.paperchase-shop-theme .woocommerce-message .button.wc-forward,
body.paperchase-shop-theme .woocommerce-message a.button.wc-forward,
body.paperchase-shop-theme .woocommerce-message a.wc-forward,
body.paperchase-shop-theme .woocommerce-message a.wp-element-button.wc-forward,
body.paperchase-shop-theme .woocommerce-info .button.wc-forward,
body.paperchase-shop-theme .woocommerce-info a.button.wc-forward,
body.paperchase-shop-theme .woocommerce-info a.wc-forward,
body.paperchase-shop-theme .woocommerce-message .pcs-woo-cart-notice-cta,
body.paperchase-shop-theme .woocommerce-info .pcs-woo-cart-notice-cta,
body.paperchase-shop-theme .wc-block-components-notice-banner .wc-block-components-notice-banner__content .wc-forward,
body.paperchase-shop-theme .wc-block-components-notice-banner__content a.wc-forward,
body.paperchase-shop-theme .wc-block-components-notice-banner.is-success .wc-block-components-notice-banner__content .wc-forward,
.pcs-woo-shop .woocommerce-notices-wrapper a.wc-forward,
.pcs-woo-shop .woocommerce-message .button.wc-forward,
.pcs-woo-shop .woocommerce-message a.button.wc-forward,
.pcs-woo-shop .woocommerce-message a.wc-forward,
.pcs-woo-shop .woocommerce-message a.wp-element-button.wc-forward,
.pcs-woo-shop .woocommerce-info .button.wc-forward,
.pcs-woo-shop .woocommerce-info a.button.wc-forward,
.pcs-woo-shop .woocommerce-info a.wc-forward,
.pcs-woo-shop .woocommerce-message .pcs-woo-cart-notice-cta,
.pcs-woo-shop .woocommerce-info .pcs-woo-cart-notice-cta,
body.woocommerce.single-product .woocommerce-notices-wrapper a.wc-forward {
    -webkit-appearance: none;
    appearance: none;
    float: none !important;
    opacity: 1 !important;
    display: inline-block;
    box-sizing: border-box;
    margin-top: 0.65rem;
    margin-inline: 0;
    background: var(--pcs-distribution-blue, #173cc8) !important;
    background-image: none !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    border-bottom: 5px solid #fff !important;
    box-shadow: none !important;
    outline: none;
    font-family: "Heavy", "futuraheavy", var(--pcs-font-display, "Jost", sans-serif) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.033em !important;
    font-size: clamp(0.68rem, 3.2vw, 0.78rem) !important;
    line-height: 1.2 !important;
    padding: 0.62rem 0.95rem !important;
    text-decoration: none !important;
    text-align: center;
    transform: skew(-10deg);
    cursor: pointer;
    transition:
        background 0.25s ease,
        border-bottom-color 0.25s ease,
        color 0.25s ease;
}

body.paperchase-shop-theme .woocommerce-notices-wrapper a.wc-forward:hover,
body.paperchase-shop-theme .woocommerce-notices-wrapper a.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-message .button.wc-forward:hover,
body.paperchase-shop-theme .woocommerce-message .button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-message a.button.wc-forward:hover,
body.paperchase-shop-theme .woocommerce-message a.button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-message a.wc-forward:hover,
body.paperchase-shop-theme .woocommerce-message a.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-info .button.wc-forward:hover,
body.paperchase-shop-theme .woocommerce-info .button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-info a.button.wc-forward:hover,
body.paperchase-shop-theme .woocommerce-info a.button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-info a.wc-forward:hover,
body.paperchase-shop-theme .woocommerce-info a.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-message .pcs-woo-cart-notice-cta:hover,
body.paperchase-shop-theme .woocommerce-message .pcs-woo-cart-notice-cta:focus-visible,
body.paperchase-shop-theme .wc-block-components-notice-banner .wc-forward:hover,
body.paperchase-shop-theme .wc-block-components-notice-banner .wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-notices-wrapper a.wc-forward:hover,
.pcs-woo-shop .woocommerce-notices-wrapper a.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-message .button.wc-forward:hover,
.pcs-woo-shop .woocommerce-message .button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-message a.button.wc-forward:hover,
.pcs-woo-shop .woocommerce-message a.button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-message a.wc-forward:hover,
.pcs-woo-shop .woocommerce-message a.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-info .button.wc-forward:hover,
.pcs-woo-shop .woocommerce-info .button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-info a.button.wc-forward:hover,
.pcs-woo-shop .woocommerce-info a.button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-info a.wc-forward:hover,
.pcs-woo-shop .woocommerce-info a.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-message .pcs-woo-cart-notice-cta:hover,
.pcs-woo-shop .woocommerce-message .pcs-woo-cart-notice-cta:focus-visible,
body.woocommerce.single-product .woocommerce-notices-wrapper a.wc-forward:hover,
body.woocommerce.single-product .woocommerce-notices-wrapper a.wc-forward:focus-visible {
    background: #1e4ae0 !important;
    color: #fff !important;
    border-bottom-color: var(--pcs-publishing-gold, #ffcb00) !important;
}

body.paperchase-shop-theme a.added_to_cart.wc-forward:focus-visible,
body.pcs-woo-shop a.added_to_cart.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-notices-wrapper a.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-message .button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-message a.button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-message a.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-info .button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-info a.button.wc-forward:focus-visible,
body.paperchase-shop-theme .woocommerce-info a.wc-forward:focus-visible,
body.paperchase-shop-theme .wc-block-components-notice-banner .wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-notices-wrapper a.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-message .button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-message a.button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-message a.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-info .button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-info a.button.wc-forward:focus-visible,
.pcs-woo-shop .woocommerce-info a.wc-forward:focus-visible,
body.woocommerce.single-product .woocommerce-notices-wrapper a.wc-forward:focus-visible {
    outline: 2px solid var(--pcs-publishing-gold, #ffcb00);
    outline-offset: 3px;
}

@media (max-width: 599px) {
    body.paperchase-shop-theme a.added_to_cart.wc-forward,
    body.pcs-woo-shop a.added_to_cart.wc-forward,
    body.paperchase-shop-theme ul.products a.added_to_cart.wc-forward,
    body.paperchase-shop-theme .woocommerce-notices-wrapper a.wc-forward,
    body.paperchase-shop-theme .woocommerce-message .button.wc-forward,
    body.paperchase-shop-theme .woocommerce-message a.button.wc-forward,
    body.paperchase-shop-theme .woocommerce-message a.wc-forward,
    body.paperchase-shop-theme .woocommerce-info .button.wc-forward,
    body.paperchase-shop-theme .woocommerce-info a.button.wc-forward,
    body.paperchase-shop-theme .woocommerce-info a.wc-forward,
    body.paperchase-shop-theme .wc-block-components-notice-banner .wc-forward,
    .pcs-woo-shop .woocommerce-notices-wrapper a.wc-forward,
    .pcs-woo-shop .woocommerce-message .button.wc-forward,
    .pcs-woo-shop .woocommerce-message a.button.wc-forward,
    .pcs-woo-shop .woocommerce-message a.wc-forward,
    .pcs-woo-shop .woocommerce-info .button.wc-forward,
    .pcs-woo-shop .woocommerce-info a.button.wc-forward,
    .pcs-woo-shop .woocommerce-info a.wc-forward,
    body.woocommerce.single-product .woocommerce-notices-wrapper a.wc-forward {
        display: block;
        width: 100%;
        max-width: 100%;
        margin-top: 0.9rem;
    }
}

/* —— Pagination ——
 * Klassiek shop-archief (archive-product.php) heeft geen <div class="woocommerce"> rond de loop;
 * alleen body.woocommerce — oude selectors .pcs-woo-shop .woocommerce nav… matchten dus niet
 * en paginatie viel terug op browser-default (bullets, geen flex). Zie ook hub.css (stores-archive).
 */
body.pcs-woo-shop nav.woocommerce-pagination,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination {
    margin: 2.25rem auto 0;
    padding: 0 clamp(0.5rem, 2vw, 1rem);
    clear: both;
}

body.pcs-woo-shop nav.woocommerce-pagination ul,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul {
    border: none;
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.45rem 0.65rem;
}

body.pcs-woo-shop nav.woocommerce-pagination ul li,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li {
    border: none;
    margin: 0;
    padding: 0;
    list-style: none;
}

body.pcs-woo-shop nav.woocommerce-pagination ul li a,
body.pcs-woo-shop nav.woocommerce-pagination ul li span,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li a,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li span {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    min-height: 2.5rem;
    padding: 0.35rem 0.7rem;
    background: rgba(0, 0, 0, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--pcs-radius-container, 9px);
    color: var(--pcs-text-distribution, #e8e8e8);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-decoration: none;
    transition:
        border-color var(--pcs-ease, 0.2s ease),
        background var(--pcs-ease, 0.2s ease),
        color var(--pcs-ease, 0.2s ease),
        box-shadow var(--pcs-ease, 0.2s ease);
}

body.pcs-woo-shop nav.woocommerce-pagination ul li a:hover,
body.pcs-woo-shop nav.woocommerce-pagination ul li a:focus-visible,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li a:hover,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li a:focus-visible {
    border-color: color-mix(in srgb, var(--pcs-publishing-gold) 48%, transparent);
    color: var(--pcs-publishing-gold);
    box-shadow: 0 0 20px color-mix(in srgb, var(--pcs-publishing-gold) 14%, transparent);
    outline: none;
}

body.pcs-woo-shop nav.woocommerce-pagination ul li a:focus-visible,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li a:focus-visible {
    outline: 2px solid var(--pcs-publishing-gold, #ffcb00);
    outline-offset: 2px;
}

body.pcs-woo-shop nav.woocommerce-pagination ul li span.current,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li span.current {
    border-color: color-mix(in srgb, var(--pcs-publishing-gold) 45%, transparent);
    background: color-mix(in srgb, var(--pcs-publishing-gold) 20%, rgba(0, 0, 0, 0.45));
    color: var(--pcs-publishing-gold);
    box-shadow: none;
    cursor: default;
}

body.pcs-woo-shop nav.woocommerce-pagination ul li span.dots,
.pcs-woo-shop .woocommerce nav.woocommerce-pagination ul li span.dots {
    border: none;
    background: transparent;
    min-width: auto;
    box-shadow: none;
    opacity: 0.55;
}

/* Header winkelmand: zie assets/css/shop/header-cart.css (ook op home/hub geladen). */
