/* ── Classic cart: allow Select2 dropdown to escape table cell clipping ── */
.woocommerce-cart table.woocommerce-cart-form__contents,
.woocommerce-cart table.shop_table,
.woocommerce-cart-form table,
.woocommerce-cart-form table td {
    overflow: visible !important;
}

.ext-pq-classic-cart-qty {
    position: relative;
    overflow: visible;
    z-index: 1;
}

.ext-pq-classic-cart-qty .select2-container {
    position: relative;
}

/* Classic cart: dropdown is on document.body — keep label/trigger below the panel */
.woocommerce-cart-form td.product-quantity:has(.select2-container--open) {
    z-index: 1 !important;
    position: relative;
}

.ext-pq-classic-cart-qty:has(.select2-container--open) .ext-pq-cart-dropdown-label {
    position: relative;
    z-index: 0;
    pointer-events: none;
}

.ext-pq-classic-cart-qty:has(.select2-container--open) .select2-container {
    position: relative;
    z-index: 0;
}
/* Center-align quantity and buttons in Up-sells and Cross-sells */
.upsells.products .product .parentEXTQty,
.cross-sells.products .product .parentEXTQty,
.related.products .product .parentEXTQty {
    display: flex;
    margin-left: auto;
    margin-right: auto;
    width: fit-content;
}

/* Center quantity control on block theme product loop (shop/grid) */
.wc-block-grid .ext-pq-block-wrapper .parentEXTQty,
.wp-block-woocommerce-product-grid .ext-pq-block-wrapper .parentEXTQty {
    display: flex;
    flex-direction: column;
    align-items: center;
}

/*
 * Shop loop: wrapper gets class ext-pq-loop (PHP) — fit to spinner, button 100%.
 * Fallback if inline block is missing or overridden.
 */
.ext-pq-loop.ext-pq-block-wrapper {
    width: fit-content !important;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    display: block;
    box-sizing: border-box;
}
.ext-pq-loop .parentEXTQty {
    align-items: stretch;
}
.ext-pq-loop .ext-pq-ajax-add-to-cart,
.ext-pq-loop a.add_to_cart_button {
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    text-align: center;
}

/*
 * Shop / archive / product grid: inline PHP sets .ext-pq-block-wrapper and
 * .parentEXTQty to width:100%, which stretches quantity + buttons across the
 * whole card. Constrain to content width and center (same idea as related
 * upsells fit-content rule above).
 */
body.ext-pq-is-block-theme .wc-block-grid .ext-pq-block-wrapper,
body.ext-pq-is-block-theme .wp-block-woocommerce-product-grid .ext-pq-block-wrapper,
body.post-type-archive-product .ext-pq-block-wrapper,
body.woocommerce-shop .ext-pq-block-wrapper,
body.tax-product_cat .ext-pq-block-wrapper,
body.tax-product_tag .ext-pq-block-wrapper {
    width: auto !important;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}

body.ext-pq-is-block-theme .wc-block-grid .ext-pq-block-wrapper .parentEXTQty,
body.ext-pq-is-block-theme .wp-block-woocommerce-product-grid .ext-pq-block-wrapper .parentEXTQty,
body.post-type-archive-product .ext-pq-block-wrapper .parentEXTQty,
body.woocommerce-shop .ext-pq-block-wrapper .parentEXTQty {
    width: auto !important;
    max-width: 100%;
    align-items: center;
}

/*
 * Loop buttons: don’t stretch to full column — except .ext-pq-loop where we WANT
 * button width 100% to match spinner (inline block sets that; these rules must not override).
 */
body.ext-pq-is-block-theme .wc-block-grid .ext-pq-block-wrapper:not(.ext-pq-loop) .ext-pq-ajax-add-to-cart,
body.ext-pq-is-block-theme .wp-block-woocommerce-product-grid .ext-pq-block-wrapper:not(.ext-pq-loop) .ext-pq-ajax-add-to-cart,
body.post-type-archive-product .ext-pq-block-wrapper:not(.ext-pq-loop) .ext-pq-ajax-add-to-cart,
body.woocommerce-shop .ext-pq-block-wrapper:not(.ext-pq-loop) .ext-pq-ajax-add-to-cart,
body.ext-pq-is-block-theme .wc-block-grid .ext-pq-block-wrapper:not(.ext-pq-loop) a.add_to_cart_button,
body.ext-pq-is-block-theme .wc-block-grid .ext-pq-block-wrapper:not(.ext-pq-loop) a.product_type_variable,
body.ext-pq-is-block-theme .wc-block-grid .ext-pq-block-wrapper:not(.ext-pq-loop) a.product_type_grouped {
    width: auto !important;
    max-width: 100%;
    display: inline-block;
    box-sizing: border-box;
    padding-left: 1rem;
    padding-right: 1rem;
}

/* Product collection / product-button block: center the shrink-wrapped stack */
li.wc-block-product [data-block-name="woocommerce/product-button"].ext-pq-loop,
li.wc-block-product .ext-pq-block-wrapper.ext-pq-loop {
    width: fit-content !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: block !important;
    box-sizing: border-box;
}
li.wc-block-product .ext-pq-loop .parentEXTQty {
    width: auto !important;
    max-width: 100%;
}
li.wc-block-product .ext-pq-loop .ext-pq-ajax-add-to-cart {
    width: 100% !important;
    display: block !important;
    box-sizing: border-box;
    text-align: center;
}

/* Classic loop (non-block theme) product cards */
.woocommerce ul.products li.product .ext-pq-block-wrapper {
    width: auto !important;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    display: block;
}

.woocommerce ul.products li.product .ext-pq-block-wrapper .parentEXTQty {
    width: auto !important;
    max-width: 100%;
}

.input-group.spinner {
    display: flex;
    text-align: center;
    width: fit-content;
}

.extMarginItems {
    margin: 1px auto;
}

.input-group-btn-vertical {
    display: flex;
    flex-direction: column;
}

.input-text.extPQQuantity,
.input-text.ext_single_qty,
.ext-pq-block-input,
.extCenterItems {
    text-align: center;
}

.ext-pq-block-input {
    padding: 0 !important;
}

.btn-default,
.extPQPlusMinusButtons {
    min-width: 10px;
    text-align: center;
    overflow: hidden;
    padding: 1px 6px;
}

.btn-default svg {
    height: 12px;
}

/* Non-block themes — Default vertical spinner: arrow stack matches input height */
body:not(.ext-pq-is-block-theme) .input-group.spinner,
body:not(.ext-pq-is-block-theme) .ext-pq-cart-default.input-group.spinner {
    display: inline-flex;
    align-items: stretch;
    width: fit-content;
}

body:not(.ext-pq-is-block-theme) .input-group.spinner .input-text.extPQQuantity,
body:not(.ext-pq-is-block-theme) .input-group.spinner .ext-pq-classic-cart-display,
body:not(.ext-pq-is-block-theme) .ext-pq-cart-default .ext-pq-classic-cart-display,
body:not(.ext-pq-is-block-theme) .ext-pq-cart-default .ext-pq-block-input {
    align-self: stretch;
    height: auto;
    box-sizing: border-box;
}

body:not(.ext-pq-is-block-theme) .input-group.spinner .input-group-btn-vertical,
body:not(.ext-pq-is-block-theme) .ext-pq-cart-default .input-group-btn-vertical {
    display: flex;
    flex-direction: column;
    align-self: stretch;
}

body:not(.ext-pq-is-block-theme) .input-group.spinner .input-group-btn-vertical .btn,
body:not(.ext-pq-is-block-theme) .ext-pq-cart-default .input-group-btn-vertical .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 50%;
    min-height: 0;
    min-width: 2em;
    width: 2em;
    padding: 2px 6px;
    overflow: visible;
    color: #333;
    box-sizing: border-box;
}

body:not(.ext-pq-is-block-theme) .input-group.spinner .input-group-btn-vertical .btn svg,
body:not(.ext-pq-is-block-theme) .ext-pq-cart-default .input-group-btn-vertical .btn svg {
    height: 12px;
    width: 12px;
    display: block;
    fill: currentColor;
}

body:not(.ext-pq-is-block-theme) .input-group.spinner .input-group-btn-vertical .btn svg path,
body:not(.ext-pq-is-block-theme) .ext-pq-cart-default .input-group-btn-vertical .btn svg path {
    fill: currentColor;
}

/* Same quantity button/input styling only on block themes (no Bootstrap); regular themes keep the rules above */
body.ext-pq-is-block-theme .ext-pq-block-wrapper .btn-default,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .extPQPlusMinusButtons,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .pq-minus-btn,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .pq-plus-btn,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-minus,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-plus,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-block-minus,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-block-plus,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-block-minus,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-block-plus {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    min-height: 32px;
    padding: 6px 10px;
    font-size: 16px;
    line-height: 1;
    color: #333;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .btn-default:hover,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .extPQPlusMinusButtons:hover,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .pq-minus-btn:hover,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .pq-plus-btn:hover,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-minus:hover,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-plus:hover,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-block-minus:hover,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-block-plus:hover,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-block-minus:hover,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-block-plus:hover {
    background-color: #f5f5f5;
    border-color: #adadad;
}

/* Cart page — horizontal +/- (match shop plus-minus layout) */
.woocommerce-cart-form .ext-pq-classic-cart-qty .quantity_plus_minus,
.ext-pq-block-qty-wrapper .quantity_plus_minus {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    flex-wrap: nowrap;
}

.woocommerce-cart-form .ext-pq-classic-cart-qty .quantity_plus_minus .ext-pq-classic-cart-display,
.ext-pq-block-qty-wrapper .quantity_plus_minus .ext-pq-block-input {
    width: 2.75em !important;
    min-width: 2.25em !important;
    max-width: 4.5em;
    min-height: unset !important;
    height: auto;
    padding: 4px 6px !important;
    font-size: 14px;
    line-height: 1.2;
    text-align: center;
    box-sizing: border-box;
}

/* Cart +/- buttons — same height as the qty input (override block-theme 32px defaults) */
.woocommerce-cart-form .quantity_plus_minus .ext-pq-cart-minus,
.woocommerce-cart-form .quantity_plus_minus .ext-pq-cart-plus,
.ext-pq-block-qty-wrapper .quantity_plus_minus .ext-pq-block-minus,
.ext-pq-block-qty-wrapper .quantity_plus_minus .ext-pq-block-plus,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .quantity_plus_minus .ext-pq-block-minus,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .quantity_plus_minus .ext-pq-block-plus,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .quantity_plus_minus .ext-pq-block-minus,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .quantity_plus_minus .ext-pq-block-plus {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.25em !important;
    width: 2.25em !important;
    max-width: 2.25em;
    min-height: unset !important;
    height: auto;
    padding: 4px 0 !important;
    font-size: 14px !important;
    line-height: 1.2;
    box-sizing: border-box;
    flex: 0 0 auto;
}

/* Cart page — vertical spinner (match shop Default layout) */
.woocommerce-cart-form .ext-pq-cart-default.input-group.spinner,
.ext-pq-block-qty-wrapper .ext-pq-cart-default.input-group.spinner {
    display: inline-flex;
    align-items: stretch;
    width: fit-content;
    text-align: center;
}

.woocommerce-cart-form .ext-pq-cart-default .input-group-btn-vertical,
.ext-pq-block-qty-wrapper .ext-pq-cart-default .input-group-btn-vertical {
    display: flex;
    flex-direction: column;
}

.woocommerce-cart-form .ext-pq-cart-default .input-group-btn-vertical .btn,
.ext-pq-block-qty-wrapper .ext-pq-cart-default .input-group-btn-vertical .btn {
    font-size: 12px;
}

.woocommerce-cart-form .ext-pq-cart-default .input-group-btn-vertical .btn svg,
.ext-pq-block-qty-wrapper .ext-pq-cart-default .input-group-btn-vertical .btn svg {
    height: 12px;
    width: 12px;
    display: block;
    fill: currentColor;
}

.woocommerce-cart-form .ext-pq-cart-default .input-group-btn-vertical .btn svg path,
.ext-pq-block-qty-wrapper .ext-pq-cart-default .input-group-btn-vertical .btn svg path {
    fill: currentColor;
}

/* Cart page — compact quantity input (classic + block) */
.woocommerce-cart-form .ext-pq-cart-default .ext-pq-classic-cart-display,
.ext-pq-block-qty-wrapper .ext-pq-cart-default .ext-pq-block-input,
.woocommerce-cart-form .ext-pq-classic-cart-display,
.ext-pq-block-qty-wrapper .ext-pq-block-input,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-input {
    min-width: 2.25em !important;
    max-width: 4.5em;
    padding: 4px 6px !important;
    text-align: center;
    box-sizing: border-box;
}

.woocommerce-cart-form select.ext-pq-cart-select:not(.select2-hidden-accessible),
.ext-pq-block-qty-wrapper select.ext-pq-block-select:not(.select2-hidden-accessible) {
    width: auto !important;
    min-width: 3.5em;
    max-width: 6em;
}

/* Classic cart: native <select> must not receive clicks before Select2 init */
.woocommerce-cart-form select.ext-pq-cart-select:not(.select2-hidden-accessible) {
    pointer-events: none;
}

/* Keep Select2’s clipped native <select> hidden (cart width rules must not override). */
.ext-pq-block-qty-wrapper select.ext-pq-block-select.select2-hidden-accessible,
.woocommerce-cart-form select.ext-pq-cart-select.select2-hidden-accessible {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
    min-width: 0 !important;
    max-width: none !important;
}

/* Cart dropdown — label stacked above select */
.ext-pq-cart-dropdown {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: fit-content;
    position: relative;
    z-index: 20;
    overflow: visible;
}

.ext-pq-cart-dropdown-label {
    display: block;
    width: 100%;
    text-align: center;
    line-height: 1.3;
}

/* Cart block: hidden native quantity selector must not take width (kept in DOM for block state) */
.wc-block-cart-item__quantity .wc-block-components-quantity-selector[aria-hidden="true"],
.wc-block-mini-cart-item__quantity .wc-block-components-quantity-selector[aria-hidden="true"] {
    width: 0 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    flex: 0 0 0 !important;
    visibility: hidden;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .quantity_plus_minus,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .quantity_plus_minus,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
}

/*
 * Match input height to the stacked +/- column. height:100% doesn’t work here
 * — no ancestor has an explicit height, so % resolves to auto. Use flex stretch
 * so the input shares the cross-size of the flex line (driven by .input-group-btn-vertical).
 */
body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner {
    align-items: stretch;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner .input-text.extPQQuantity {
    min-height: unset;
    align-self: stretch;
    height: auto;
    box-sizing: border-box;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group-btn-vertical {
    display: flex;
    flex-direction: column;
    justify-content: stretch;
    align-self: stretch;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group-btn-vertical .btn {
    flex: 1 1 50%;
    min-height: 0;
}

/* Input height on block themes — shop +/- only (Default spinner uses compact rules below) */
body.ext-pq-is-block-theme .ext-pq-block-wrapper .quantity_plus_minus .input-text.extPQQuantity,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .quantity_plus_minus .ext_single_qty {
    width: 4em;
    min-width: 3em;
    min-height: 32px;
    box-sizing: border-box;
    text-align: center;
    padding: 6px 8px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
    background-color: #fff;
}

/* Block theme — compact Default vertical spinner (shop, cart, mini-cart) */
body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner .input-text.extPQQuantity,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-cart-default .ext-pq-block-input {
    width: 2.75em;
    min-width: 2.25em;
    min-height: unset;
    box-sizing: border-box;
    text-align: center;
    padding: 3px 6px;
    font-size: 13px;
    line-height: 1.2;
    border: 1px solid #ccc;
    border-radius: 4px;
    background-color: #fff;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner .input-group-btn-vertical .btn,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-cart-default .input-group-btn-vertical .btn,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-cart-default .input-group-btn-vertical .btn,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-cart-default .input-group-btn-vertical .btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-width: 2.25em !important;
    width: 2.5em !important;
    max-width: 2.25em;
    min-height: unset !important;
    height: auto;
    padding: 2px 6px !important;
    flex: 1 1 50%;
    line-height: 1;
    border-radius: 2px;
    overflow: visible;
    color: #333;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner .input-group-btn-vertical .btn svg,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-cart-default .input-group-btn-vertical .btn svg,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-cart-default .input-group-btn-vertical .btn svg,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-cart-default .input-group-btn-vertical .btn svg {
    height: 12px;
    width: 12px;
    flex-shrink: 0;
    display: block;
    overflow: visible;
    fill: currentColor;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner .input-group-btn-vertical .btn svg path,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-cart-default .input-group-btn-vertical .btn svg path,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-cart-default .input-group-btn-vertical .btn svg path,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-cart-default .input-group-btn-vertical .btn svg path {
    fill: currentColor;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper .quantity_plus_minus .input-text:focus,
body.ext-pq-is-block-theme .ext-pq-block-wrapper .input-group.spinner .input-text:focus,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-input:focus {
    border-color: #66afe9;
    outline: 0;
}

body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-minus:disabled,
body.ext-pq-is-block-theme .ext-pq-block-qty-wrapper .ext-pq-block-plus:disabled,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-block-minus:disabled,
body.ext-pq-is-block-theme .wc-block-cart-item__quantity .ext-pq-block-plus:disabled,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-block-minus:disabled,
body.ext-pq-is-block-theme .wc-block-mini-cart-item__quantity .ext-pq-block-plus:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background-color: #eee;
}

/* Single product page on block theme: quantity and Add to cart button in one row (quantity left, button right) */
body.ext-pq-is-block-theme.single-product .wc-block-add-to-cart-form,
body.ext-pq-is-block-theme.single-product .wp-block-woocommerce-add-to-cart-form {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
}

body.ext-pq-is-block-theme.single-product .wc-block-add-to-cart-form > *,
body.ext-pq-is-block-theme.single-product .wp-block-woocommerce-add-to-cart-form > * {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: nowrap;
}

body.ext-pq-is-block-theme.single-product .wp-block-group:has(.wc-block-components-quantity-selector),
body.ext-pq-is-block-theme.single-product .wc-block-components-add-to-cart-form > div[class*="wp-block"] {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: nowrap;
}

body.ext-pq-is-block-theme.single-product .wc-block-add-to-cart-form .wc-block-components-product-button,
body.ext-pq-is-block-theme.single-product .wc-block-add-to-cart-form .wp-block-button,
body.ext-pq-is-block-theme.single-product .wp-block-group:has(.wc-block-components-quantity-selector) .wc-block-components-product-button,
body.ext-pq-is-block-theme.single-product .wp-block-group:has(.wc-block-components-quantity-selector) .wp-block-button {
    flex: 0 0 auto;
}

/* Single product: quantity on top, Add to cart button below */
body.ext-pq-is-block-theme.single-product .wc-block-add-to-cart-form form.cart,
body.ext-pq-is-block-theme.single-product .wp-block-woocommerce-add-to-cart-form form.cart,
body.ext-pq-is-block-theme.single-product form.cart {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start;
    gap: 0.75rem;
}

/* Variable product: Add to cart sits inside .variations_button — stretch full width like simple product */
body.ext-pq-is-block-theme.single-product .variations_form .single_variation_wrap,
body.ext-pq-is-block-theme.single-product .variations_form .woocommerce-variation-add-to-cart.variations_button {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

body.ext-pq-is-block-theme.single-product .variations_form .woocommerce-variation-add-to-cart.variations_button {
    display: flex;
    flex-direction: column;
    /* Match quantity row width: don’t stretch children to full column */
    align-items: flex-start;
    align-self: flex-start;
    gap: 0.75rem;
    /* Override WC float/inline so button isn’t shrink-wrapped */
    float: none;
    clear: both;
    /* Keep wrapper from forcing full-width stripe */
    width: auto;
    max-width: 100%;
}

body.ext-pq-is-block-theme.single-product .variations_form .woocommerce-variation-add-to-cart .quantity {
    width: auto;
    max-width: 100%;
}

/* Left-aligned, similar to simple product — not full column width */
body.ext-pq-is-block-theme.single-product .variations_form .woocommerce-variation-add-to-cart .single_add_to_cart_button {
    width: auto;
    max-width: 100%;
    align-self: flex-start;
    box-sizing: border-box;
    text-align: center;
    /* Comfortable pill/block without spanning entire content area */
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

/* Single product page on block theme: style our widget AND the Add to Cart block quantity selector */
body.ext-pq-is-block-theme.single-product .ext-pq-block-wrapper .quantity_plus_minus,
body.ext-pq-is-block-theme.single-product .ext-pq-block-wrapper .parentEXTQty .container,
body.ext-pq-is-block-theme.single-product .quantity.wc-block-components-quantity-selector {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: nowrap;
}

/* WooCommerce Add to Cart block quantity (single product): same look as our quantity controls */
body.ext-pq-is-block-theme.single-product .wc-block-components-quantity-selector__button,
body.ext-pq-is-block-theme.single-product .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button--minus,
body.ext-pq-is-block-theme.single-product .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button--plus {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    min-height: 32px;
    padding: 6px 10px;
    font-size: 16px;
    line-height: 1;
    color: #333;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
}

body.ext-pq-is-block-theme.single-product .wc-block-components-quantity-selector__button:hover {
    background-color: #f5f5f5;
    border-color: #adadad;
}

body.ext-pq-is-block-theme.single-product .wc-block-components-quantity-selector__input {
    width: 4em;
    min-width: 3em;
    min-height: 32px;
    box-sizing: border-box;
    text-align: center;
    padding: 6px 8px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
    background-color: #fff;
}

body.ext-pq-is-block-theme.single-product .wc-block-components-quantity-selector__input:focus {
    border-color: #66afe9;
    outline: 0;
}

body.ext-pq-is-block-theme.single-product .wc-block-components-quantity-selector__button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background-color: #eee;
}

/* Unified Styling for both Static and Lazy Dropdowns */
.ex-dropdown.extPQQuantity,
select.ext-pq-cart-select,
select.ext-pq-block-select {
    text-align: center;
    text-align-last: center;
}

.ex-dropdown.extPQQuantity {
    min-width: 80px;
    margin-bottom: 20px;
    height: 42px !important;
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 0 35px 0 10px;
    background-color: #fff;
    display: inline-block;
    width: 150px !important;
    font-size: 14px;
    color: #333;
    cursor: pointer;
    background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23333%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.4-12.8z%22/%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-position: right 12px top 50%;
    background-size: 10px auto;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    line-height: normal;
}

.extDefault .extPQQuantity {
    width: 150px !important;
}

/* Shop / product lazy-load Select2 — scrollable results list */
.select2-dropdown.ext-pq-lazy-select2-dropdown {
    z-index: 1000001;
    border: 1px solid #ccc;
    background-color: #fff !important;
    opacity: 1 !important;
    box-sizing: border-box;
    isolation: isolate;
}

.select2-dropdown.ext-pq-lazy-select2-dropdown .select2-search--dropdown {
    background-color: #fff !important;
    opacity: 1 !important;
}

.select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results,
.select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results__options {
    background-color: #fff;
}

.select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results {
    max-height: 200px;
    overflow: hidden;
}

.select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results__options {
    max-height: 200px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
}

.select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results__option {
    color: #333;
    background-color: #fff;
}

.select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results__option--highlighted[aria-selected] {
    background-color: #5897fb;
    color: #fff;
}

body.ext-pq-is-block-theme .ext-pq-block-wrapper,
body.ext-pq-is-block-theme .parentEXTQty {
    overflow: visible;
}

/* Select2 Scoped Enhancements to match static styling above */
.select2-container.select2-container--default.ext-pq-lazy-load-container {
    width: 150px !important;
    margin-bottom: 20px;
    display: inline-block;
    vertical-align: middle;
}

/* Center selected value in plugin Select2 dropdowns (shop + classic cart) */
.parentEXTQty .select2-container.ext-pq-lazy-load-container .select2-selection--single,
.ext-pq-block-wrapper .select2-container.ext-pq-lazy-load-container .select2-selection--single,
.woocommerce-cart-form .select2-container.ext-pq-lazy-load-container .select2-selection--single {
    display: flex;
    align-items: center;
    justify-content: center;
}

.parentEXTQty .select2-container.ext-pq-lazy-load-container .select2-selection__rendered,
.ext-pq-block-wrapper .select2-container.ext-pq-lazy-load-container .select2-selection__rendered,
.woocommerce-cart-form .select2-container.ext-pq-lazy-load-container .select2-selection__rendered {
    text-align: center !important;
    width: 100%;
}

.ext-pq-block-qty-wrapper:not(.ext-pq-cart-dropdown) .select2-container.ext-pq-lazy-load-container {
    margin-bottom: 0;
    width: auto !important;
    min-width: 3.5em;
    max-width: 6em;
}

/* Block cart Select2 — match shop .ex-dropdown.extPQQuantity */
.ext-pq-cart-dropdown .select2-container.ext-pq-block-cart-select2,
.ext-pq-cart-dropdown .select2-container.ext-pq-lazy-load-container {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    margin-bottom: 0;
    display: inline-block !important;
    vertical-align: middle;
    height: 42px !important;
}

.ext-pq-cart-dropdown .select2-container.ext-pq-block-cart-select2 .select2-selection--single {
    height: 42px !important;
    min-height: 42px;
    border: 1px solid #ccc !important;
    border-radius: 4px;
    background-color: #ffffff !important;
    background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23333%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.4-12.8z%22/%3E%3C/svg%3E') !important;
    background-repeat: no-repeat !important;
    background-position: right 12px top 50% !important;
    background-size: 10px auto !important;
    padding: 0 35px 0 10px;
    box-sizing: border-box;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 42px !important;
}

.ext-pq-cart-dropdown .select2-container.ext-pq-block-cart-select2 .select2-selection__rendered {
    line-height: 42px !important;
    padding: 0;
    color: #333333 !important;
    text-align: center;
    width: 100%;
    font-size: 14px;
    display: block !important;
}

.ext-pq-cart-dropdown .select2-container.ext-pq-block-cart-select2 .select2-selection__arrow {
    display: none;
}

/* Block cart Select2 — open list (inside .ext-pq-cart-dropdown) */
.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown {
    z-index: 1000001;
    width: 150px !important;
    min-width: 150px !important;
    border: 1px solid #ccc !important;
    border-radius: 4px;
    background-color: #ffffff !important;
    box-sizing: border-box;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown .select2-results,
.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__options {
    background-color: #ffffff !important;
}

.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown .select2-results {
    max-height: 220px;
    overflow: hidden;
}

.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__options {
    list-style: none !important;
    margin: 0;
    padding: 0;
    max-height: 220px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
}

.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__option {
    list-style: none !important;
    margin: 0;
    padding: 8px 12px;
    cursor: pointer;
    color: #333333 !important;
    background-color: #ffffff !important;
}

.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__option--highlighted[aria-selected] {
    background-color: #5897fb !important;
    color: #ffffff !important;
}

/* Block cart quantity cell — allow dropdown to overlay row */
.wc-block-cart-item__quantity,
.wc-block-mini-cart-item__quantity {
    position: relative;
}

.wc-block-cart-item__quantity .ext-pq-cart-dropdown,
.wc-block-mini-cart-item__quantity .ext-pq-cart-dropdown {
    overflow: visible;
    position: relative;
    z-index: 1;
}

/* Dropdown panel is on document.body — keep cell z-index low so label/trigger don't cover the list */
.wc-block-cart-item__quantity:has(.select2-container--open),
.wc-block-mini-cart-item__quantity:has(.select2-container--open) {
    z-index: 1 !important;
    position: relative;
}

.ext-pq-cart-dropdown:has(.select2-container--open) .ext-pq-cart-dropdown-label {
    position: relative;
    z-index: 0;
    pointer-events: none;
}

.ext-pq-cart-dropdown:has(.select2-container--open) .select2-container {
    position: relative;
    z-index: 0;
}

.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown,
.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown * {
    box-sizing: border-box;
}

/* Block cart dropdown: keep search visible and constrained */
.ext-pq-cart-dropdown .select2-dropdown.ext-pq-cart-select2-dropdown {
    overflow: hidden;
}

/* Body-appended block cart dropdown — solid panel (escapes cart table stacking) */
.select2-dropdown.ext-pq-cart-select2-dropdown {
    z-index: 1000010 !important;
    pointer-events: auto;
    width: 150px !important;
    min-width: 150px !important;
    border: 1px solid #ccc !important;
    border-radius: 4px;
    background-color: #ffffff !important;
    opacity: 1 !important;
    box-sizing: border-box;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
    overflow: hidden;
    isolation: isolate;
}

.select2-dropdown.ext-pq-cart-select2-dropdown,
.select2-dropdown.ext-pq-cart-select2-dropdown * {
    box-sizing: border-box;
}

.select2-dropdown.ext-pq-cart-select2-dropdown .select2-results,
.select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__options,
.select2-dropdown.ext-pq-cart-select2-dropdown .select2-search--dropdown {
    background-color: #ffffff !important;
    opacity: 1 !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__options {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__option {
    list-style: none !important;
    list-style-type: none !important;
    margin: 0 !important;
    padding: 8px 12px;
    cursor: pointer;
    color: #333333 !important;
    background-color: #ffffff !important;
    pointer-events: auto;
}

.select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__options {
    padding-bottom: 4px !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown .select2-results__option--highlighted[aria-selected] {
    background-color: #5897fb !important;
    color: #ffffff !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown:not(.ext-pq-lazy-select2-dropdown) .select2-results {
    max-height: 220px;
    overflow: hidden;
    background-color: #ffffff !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown:not(.ext-pq-lazy-select2-dropdown) .select2-results__options {
    max-height: 220px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
}

.select2-dropdown.ext-pq-cart-select2-dropdown:not(.ext-pq-lazy-select2-dropdown) .select2-search--dropdown {
    display: none !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown.ext-pq-lazy-select2-dropdown .select2-search--dropdown {
    display: block !important;
    padding: 6px !important;
    margin: 0;
    width: 100%;
    background-color: #ffffff !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown.ext-pq-lazy-select2-dropdown .select2-search__field {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 6px 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box;
    background-color: #ffffff !important;
}

/* Block cart lazy-load — scroll on Select2 $results (ul.select2-results__options) */
.select2-dropdown.ext-pq-cart-select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results {
    max-height: none !important;
    overflow: visible !important;
    background-color: #ffffff !important;
}

.select2-dropdown.ext-pq-cart-select2-dropdown.ext-pq-lazy-select2-dropdown .select2-results__options {
    max-height: 140px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    background-color: #ffffff !important;
}