/* ==========================================================================
   CAMSCO — WooCommerce Template Overrides
   ========================================================================== */

/* ---- WooCommerce icon font (used for star ratings) ---- */
@font-face {
    font-family: WooCommerce;
    src: url('/wp-content/plugins/woocommerce/assets/fonts/WooCommerce.woff2') format('woff2'),
         url('/wp-content/plugins/woocommerce/assets/fonts/WooCommerce.woff') format('woff'),
         url('/wp-content/plugins/woocommerce/assets/fonts/WooCommerce.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}

/* ---- Star rating widget ---- */
.woocommerce p.stars { margin-bottom: 12px; }
.woocommerce p.stars a {
    position: relative;
    height: 1em;
    width: 1em;
    text-indent: -999em;
    display: inline-block;
    text-decoration: none;
    font-size: 1.4rem;
    color: var(--primary);
}
.woocommerce p.stars a::before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 1em;
    height: 1em;
    line-height: 1;
    font-family: WooCommerce;
    content: "\e021";
    text-indent: 0;
}
.woocommerce p.stars a:hover ~ a::before { content: "\e021"; }
.woocommerce p.stars:hover a::before     { content: "\e020"; color: var(--primary); }
.woocommerce p.stars.selected a.active::before        { content: "\e020"; }
.woocommerce p.stars.selected a.active ~ a::before    { content: "\e021"; }
.woocommerce p.stars.selected a:not(.active)::before  { content: "\e020"; }

/* ---- Page wrappers ---- */
.woo-main { padding: 40px 0 60px; }

/* ---- Breadcrumb ---- */
.woocommerce-breadcrumb {
    font-size: .8rem;
    color: var(--muted);
    margin-bottom: 0;
    display: block;
}
.woocommerce-breadcrumb a {
    color: var(--primary);
    text-decoration: none;
}
.woocommerce-breadcrumb a:hover { text-decoration: underline; }

/* ---- Category page header ---- */
.catalog-page-header { padding-top: 24px; margin-bottom: 8px; }
.catalog-cat-header { margin-bottom: 24px; }
.catalog-cat-title {
    font-family: var(--font-heading);
    font-size: clamp(1.4rem, 3vw, 2rem);
    font-weight: 700;
    color: var(--body);
    margin-bottom: 8px;
}
.catalog-cat-desc { color: var(--muted); font-size: .95rem; }

/* ---- Result count ---- */
.woocommerce-result-count {
    font-size: .825rem;
    color: var(--muted);
    margin: 0 0 16px;
}

/* ---- No products found ---- */
.woocommerce-info {
    background: var(--lighter-bg);
    color: var(--primary);
    border-left: 4px solid var(--primary);
    padding: 14px 20px;
    border-radius: var(--radius);
    margin-bottom: 20px;
    font-size: .9rem;
    list-style: none;
}

/* ==========================================================================
   SINGLE PRODUCT PAGE
   ========================================================================== */

body.single-product div.product:not(.product-card) {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 52px;
    align-items: start;
    margin-top: 8px;
}

/* Gallery column */
.woocommerce div.product .woocommerce-product-gallery {
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--lighter-bg);
    position: relative;
}
/* WC sets opacity:0 until JS initializes; force it visible */
.woocommerce div.product .woocommerce-product-gallery {
    opacity: 1 !important;
    transition: opacity .25s ease-in-out;
}
.woocommerce div.product .woocommerce-product-gallery img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    aspect-ratio: 4/3;
    padding: 16px;
    background: var(--lighter-bg);
}
/* Thumbnail strip */
.woocommerce div.product .woocommerce-product-gallery__trigger { display: none; }
.woocommerce div.product .flex-control-thumbs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 12px;
    border-top: 1px solid var(--border);
    margin: 0;
    list-style: none;
}
.woocommerce div.product .flex-control-thumbs li { margin: 0; }
.woocommerce div.product .flex-control-thumbs img {
    width: 64px;
    height: 64px;
    object-fit: cover;
    border-radius: 4px;
    border: 2px solid transparent;
    cursor: pointer;
    padding: 0;
    aspect-ratio: unset;
}
.woocommerce div.product .flex-control-thumbs .flex-active { border-color: var(--primary); }

/* Summary column */
.woocommerce div.product .summary.entry-summary { padding: 4px 0; }

.woocommerce div.product .product_title {
    font-family: var(--font-heading);
    font-size: clamp(1.3rem, 2.5vw, 1.75rem);
    font-weight: 700;
    margin-bottom: 10px;
    color: var(--body);
    line-height: 1.25;
}

/* Price */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 20px;
    display: block;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
    font-size: 1rem;
    opacity: .55;
    font-weight: 400;
    margin-right: 6px;
}
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
    text-decoration: none;
}

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
    color: var(--muted);
    font-size: .9rem;
    line-height: 1.65;
    margin-bottom: 24px;
}

/* ---- Variations form ---- */
.woocommerce div.product form.cart { margin-bottom: 24px; }

.woocommerce div.product form.cart .variations {
    width: 100%;
    border: none;
    border-collapse: collapse;
    margin-bottom: 16px;
}
.woocommerce div.product form.cart .variations tbody { display: block; }
.woocommerce div.product form.cart .variations tr {
    display: block;
    margin-bottom: 14px;
}
.woocommerce div.product form.cart .variations th.label {
    display: block;
    font-family: var(--font-heading);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    padding: 0 0 5px;
    border: none;
    text-align: left;
}
.woocommerce div.product form.cart .variations td.value {
    display: block;
    padding: 0;
    border: none;
}
.woocommerce div.product form.cart .variations select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: .9rem;
    color: var(--body);
    background: #fff;
    cursor: pointer;
    appearance: auto;
}
.woocommerce div.product form.cart .variations select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* Reset variations link */
.woocommerce div.product form.cart a.reset_variations {
    display: inline-block;
    font-size: .78rem;
    color: var(--muted);
    text-decoration: none;
    margin-bottom: 16px;
}
.woocommerce div.product form.cart a.reset_variations:hover { color: var(--primary); }
.woocommerce div.product form.cart a.reset_variations.woocommerce-variation-reset-button { }

/* Variation result display */
.woocommerce .woocommerce-variation.single_variation {
    padding: 12px 14px;
    background: var(--lighter-bg);
    border-radius: var(--radius);
    margin-bottom: 16px;
    font-size: .9rem;
}
.woocommerce .woocommerce-variation.single_variation:empty { display: none; }
.woocommerce .woocommerce-variation.single_variation .woocommerce-variation-price {
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--primary);
    font-size: 1.2rem;
}

/* ---- Add to cart button row ---- */
.woocommerce div.product .woocommerce-variation-add-to-cart,
.woocommerce div.product form.cart:not(.grouped_form) > .cart-button-group {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 8px;
}

/* Quantity input */
.woocommerce div.product .quantity {
    display: flex;
    align-items: center;
    gap: 0;
}
.woocommerce div.product .quantity label { display: none; }
.woocommerce div.product .quantity input[type=number] {
    width: 68px;
    padding: 12px 10px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-heading);
    font-size: .9rem;
    font-weight: 600;
    text-align: center;
    color: var(--body);
    background: #fff;
    -moz-appearance: textfield;
}
.woocommerce div.product .quantity input[type=number]::-webkit-inner-spin-button,
.woocommerce div.product .quantity input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; }
.woocommerce div.product .quantity input[type=number]:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* ---- Add to cart buttons ---- */
.woocommerce .single_add_to_cart_button,
.woocommerce button.button,
.woocommerce a.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 28px;
    font-family: var(--font-heading);
    font-size: .875rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    background: var(--primary);
    color: #fff;
    border: 2px solid var(--primary);
    border-radius: var(--radius);
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition), border-color var(--transition);
    appearance: none;
    -webkit-appearance: none;
    line-height: 1.4;
}
.woocommerce .single_add_to_cart_button:hover,
.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce .wc-proceed-to-checkout a.checkout-button:hover {
    background: var(--primary-dark);
    border-color: var(--primary-dark);
    color: #fff;
}

/* Proceed to Checkout — override WooCommerce .alt dark style */
.woocommerce a.button.alt,
.woocommerce .wc-proceed-to-checkout a.checkout-button {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
    width: 100%;
    display: flex;
    justify-content: center;
}
.woocommerce .single_add_to_cart_button:disabled,
.woocommerce button.button:disabled {
    opacity: .5;
    cursor: not-allowed;
}

/* ---- Product meta (SKU etc.) ---- */
.woocommerce div.product .product_meta {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--border);
    font-size: .85rem;
    color: var(--muted);
}
.woocommerce div.product .product_meta span { margin-right: 16px; }
.woocommerce div.product .product_meta .sku { font-family: var(--font-heading); font-weight: 600; color: var(--body); }
.woocommerce div.product .product_meta a { color: var(--primary); text-decoration: none; }

/* ---- Tabs ---- */
.woocommerce div.product .woocommerce-tabs {
    grid-column: 1 / -1;
    margin-top: 40px;
    padding-top: 40px;
    border-top: 1px solid var(--border);
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: 0;
    list-style: none;
    border-bottom: 2px solid var(--border);
    padding: 0;
    margin: 0 0 28px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li { margin: 0; padding: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 10px 22px;
    font-family: var(--font-heading);
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--muted);
    text-decoration: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: color var(--transition), border-color var(--transition);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--primary);
    border-bottom-color: var(--primary);
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
    font-size: 1.1rem;
    margin-bottom: 16px;
}
.woocommerce div.product .woocommerce-tabs .panel table { width: 100%; border-collapse: collapse; }
.woocommerce div.product .woocommerce-tabs .panel table th,
.woocommerce div.product .woocommerce-tabs .panel table td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--border);
    font-size: .875rem;
    text-align: left;
}
.woocommerce div.product .woocommerce-tabs .panel table th { font-weight: 600; color: var(--muted); width: 35%; background: var(--lighter-bg); }

/* ---- Related products ---- */
.related.products {
    grid-column: 1 / -1;
    margin-top: 48px;
    padding-top: 48px;
    border-top: 1px solid var(--border);
}
.related.products > h2 {
    font-family: var(--font-heading);
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: 24px;
}
.related.products .product-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

/* ==========================================================================
   CART & CHECKOUT — WooCommerce Blocks
   ========================================================================== */

/* ---- Outer wrapper ---- */
.wp-block-woocommerce-cart,
.wp-block-woocommerce-checkout {
    padding: 40px 24px;
    box-sizing: border-box;
}
/* Cart needs max-width:none to override WooCommerce's editor content width */
.wp-block-woocommerce-cart { max-width: none !important; }

/* ---- Cart two-column layout ----
   WooCommerce renders its own flex via .wc-block-components-sidebar-layout.
   We constrain the width and override the default 65%/35% split. */
.wp-block-woocommerce-cart .wc-block-components-sidebar-layout {
    max-width: 1200px;
    margin: 0 auto;
}
.wp-block-woocommerce-cart .wc-block-components-main {
    width: calc(100% - 412px);
    padding-right: 0;
    margin-right: 32px;
    box-sizing: border-box;
}
.wp-block-woocommerce-cart .wc-block-components-sidebar {
    width: 380px;
    padding: 0;
    box-sizing: border-box;
}

/* ---- Cart line items block ---- */
.wp-block-woocommerce-cart-items-block {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

/* Column headers */
.wc-block-cart-items__header {
    display: grid;
    grid-template-columns: 1fr auto auto auto;
    gap: 16px;
    padding: 10px 16px;
    background: var(--lighter-bg);
    border-bottom: 1px solid var(--border);
}
.wc-block-cart-items__header span {
    font-family: var(--font-heading);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--muted);
}

/* Each line item row */
.wc-block-cart-items__row {
    display: grid;
    grid-template-columns: 80px 1fr auto auto auto;
    gap: 16px;
    align-items: start;
    padding: 16px;
    border-bottom: 1px solid var(--border);
}
.wc-block-cart-items__row:last-child { border-bottom: none; }

/* Product image */
.wc-block-cart-item__image a,
.wc-block-cart-item__image img {
    display: block;
    width: 80px;
    height: 80px;
    object-fit: contain;
    border-radius: 4px;
    background: var(--lighter-bg);
    padding: 4px;
}

/* Product name + meta */
.wc-block-components-product-name {
    font-family: var(--font-heading);
    font-size: .9rem;
    font-weight: 600;
    color: var(--body);
    text-decoration: none;
    display: block;
    margin-bottom: 4px;
}
.wc-block-components-product-name:hover { color: var(--primary); }
.wc-block-components-product-details { margin: 0; }
.wc-block-components-product-details__name,
.wc-block-components-product-details__value {
    font-size: .8rem;
    color: var(--muted);
}

/* Price */
.wc-block-cart-item__prices .wc-block-components-product-price,
.wc-block-cart-item__total .wc-block-components-product-price {
    font-family: var(--font-heading);
    font-size: .9rem;
    font-weight: 600;
    color: var(--body);
}
.wc-block-components-product-price__value.is-discounted { color: var(--primary); }

/* Quantity selector */
.wc-block-components-quantity-selector {
    display: flex;
    align-items: center;
    gap: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    width: fit-content;
}
.wc-block-components-quantity-selector__button {
    background: var(--lighter-bg);
    border: none;
    width: 32px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1rem;
    color: var(--body);
    transition: background var(--transition);
    flex-shrink: 0;
}
.wc-block-components-quantity-selector__button:hover { background: var(--border); }
.wc-block-components-quantity-selector__value {
    width: 48px;
    height: 36px;
    border: none;
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border);
    text-align: center;
    font-family: var(--font-heading);
    font-size: .875rem;
    font-weight: 600;
    color: var(--body);
    background: #fff;
    -moz-appearance: textfield;
}
.wc-block-components-quantity-selector__value::-webkit-inner-spin-button,
.wc-block-components-quantity-selector__value::-webkit-outer-spin-button { -webkit-appearance: none; }
.wc-block-components-quantity-selector__value:focus {
    outline: none;
}

/* Remove item button */
.wc-block-cart-item__remove-link {
    font-size: .78rem;
    color: var(--muted);
    text-decoration: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    display: block;
    white-space: nowrap;
}
.wc-block-cart-item__remove-link:hover { color: #c62828; }

/* ---- Cart totals sidebar ---- */
.wp-block-woocommerce-cart-totals-block {
    position: sticky;
    top: 88px;
}
.wp-block-woocommerce-cart-order-summary-block {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 16px;
}

/* Totals heading — WooCommerce sets padding-left:0, so use !important */
.wc-block-cart__totals-title,
.wc-block-components-totals-wrapper .wc-block-cart__totals-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--heading);
    padding: 16px 20px !important;
    border-bottom: 1px solid var(--border);
    margin: 0;
    background: var(--lighter-bg);
}

/* Each totals row — WooCommerce zeroes left/right padding with a 3-class rule,
   so match that specificity to restore our padding */
.wc-block-components-totals-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
    font-size: .9rem;
}
.wc-block-cart .wp-block-woocommerce-cart-order-summary-block .wc-block-components-totals-item,
.wc-block-cart .wp-block-woocommerce-cart-order-summary-block .wc-block-components-totals-coupon,
.wc-block-cart .wp-block-woocommerce-cart-order-summary-block .wc-block-components-panel {
    padding-left: 20px;
    padding-right: 20px;
}
/* Coupon panel toggle button — needs explicit left/right padding in both cart and checkout */
.wp-block-woocommerce-cart-order-summary-block .wc-block-components-panel__button,
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-panel__button {
    padding-left: 20px !important;
    padding-right: 20px !important;
}
.wc-block-components-totals-item:last-child { border-bottom: none; }
.wc-block-components-totals-item__label { color: var(--muted); font-size: .875rem; }
.wc-block-components-totals-item__value {
    font-family: var(--font-heading);
    font-weight: 600;
    color: var(--body);
}

/* Order total row — bold emphasis */
.wc-block-components-totals-footer-item {
    background: var(--lighter-bg);
    padding: 14px 20px;
    border-top: 2px solid var(--border);
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: .95rem;
    color: var(--body);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--primary);
}

/* Coupon form */
.wc-block-components-totals-coupon__form {
    display: flex;
    gap: 8px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
}
.wc-block-components-totals-coupon__label {
    font-family: var(--font-heading);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    padding: 12px 20px 4px;
    display: block;
}
.wc-block-components-totals-coupon-link {
    font-size: .82rem;
    color: var(--primary);
    text-decoration: none;
    padding: 8px 20px;
    display: block;
}
.wc-block-components-totals-coupon-link:hover { text-decoration: underline; }
.wc-block-components-coupon__input input[type="text"],
.wc-block-components-coupon input[type="text"] {
    flex: 1;
    padding: 9px 12px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: .875rem;
    color: var(--body);
    background: #fff;
    box-sizing: border-box;
}
.wc-block-components-coupon__input input[type="text"]:focus,
.wc-block-components-coupon input[type="text"]:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* Shipping estimate */
.wc-block-components-totals-shipping__via { font-size: .82rem; color: var(--muted); }
.wc-block-components-shipping-calculator-button {
    font-size: .82rem;
    color: var(--primary);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    text-decoration: underline;
}

/* Proceed to checkout button wrapper */
.wp-block-woocommerce-proceed-to-checkout-block { padding: 0; }
.wc-block-cart__submit-container {
    margin-top: 0;
}

/* ---- Checkout two-column layout ---- */
.wp-block-woocommerce-checkout .wc-block-components-sidebar-layout {
    max-width: 1060px;
    margin: 0 auto;
    gap: 32px;
}
.wp-block-woocommerce-checkout .wc-block-components-main {
    width: calc(100% - 412px);
    padding: 0;
    box-sizing: border-box;
}
.wp-block-woocommerce-checkout .wc-block-components-sidebar {
    width: 380px;
    padding: 0;
    box-sizing: border-box;
}

/* 2-class specificity matches .wp-block-woocommerce-checkout .wc-block-components-main
   and comes after it in source, so padding wins */
.wp-block-woocommerce-checkout .wp-block-woocommerce-checkout-fields-block {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px 32px;
}

.wp-block-woocommerce-checkout-totals-block {
    position: sticky;
    top: 88px;
}
.wp-block-woocommerce-checkout-order-summary-block {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

/* ---- Checkout form fields ---- */
.wc-block-components-form .wc-block-components-form__field,
.wc-block-components-address-form .wc-block-components-form__field {
    margin-bottom: 16px;
}
.wc-block-components-form__field-label,
.wc-block-components-label {
    font-family: var(--font-heading);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    display: block;
    margin-bottom: 5px;
}
.wc-block-components-text-input input,
.wc-block-components-form input[type="text"],
.wc-block-components-form input[type="email"],
.wc-block-components-form input[type="tel"],
.wc-block-components-form input[type="password"],
.wc-block-components-form textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: .9rem;
    color: var(--body);
    background: #fff;
    box-sizing: border-box;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.wc-block-components-text-input input:focus,
.wc-block-components-form input[type="text"]:focus,
.wc-block-components-form input[type="email"]:focus,
.wc-block-components-form input[type="tel"]:focus,
.wc-block-components-form input[type="password"]:focus,
.wc-block-components-form textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* Native select */
.wc-block-components-select select,
.wc-block-components-country-input select,
.wc-block-components-state-input select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: .9rem;
    color: var(--body);
    background: #fff;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23555' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
    box-sizing: border-box;
    cursor: pointer;
}
.wc-block-components-select select:focus,
.wc-block-components-country-input select:focus,
.wc-block-components-state-input select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* Section headings in checkout */
.wc-block-checkout__step-title,
.wc-block-components-checkout-step__title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--heading);
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}

/* Contact info, shipping method sections */
.wc-block-checkout__contact-fields,
.wc-block-checkout__shipping-fields {
    margin-bottom: 24px;
}

/* Checkbox rows */
.wc-block-components-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: .875rem;
    color: var(--body);
    margin-bottom: 12px;
    cursor: pointer;
}
.wc-block-components-checkbox input[type="checkbox"] {
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--primary);
}

/* Shipping methods */
.wc-block-components-radio-control__option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
    font-size: .9rem;
    cursor: pointer;
}
.wc-block-components-radio-control__option:last-child { border-bottom: none; }
.wc-block-components-radio-control__option input[type="radio"] {
    accent-color: var(--primary);
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}
.wc-block-components-radio-control-accordion-option {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 8px;
    overflow: hidden;
}

/* Payment methods */
.wc-block-components-payment-methods { margin-bottom: 0; }
.wc-block-components-payment-method-label {
    font-family: var(--font-heading);
    font-size: .875rem;
    font-weight: 600;
    color: var(--body);
}
.wc-block-components-payment-method-label__visually-hidden { display: none; }

/* Order note textarea */
.wc-block-checkout__add-note textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: .875rem;
    color: var(--body);
    background: #fff;
    resize: vertical;
    min-height: 80px;
    box-sizing: border-box;
}
.wc-block-checkout__add-note textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* Place order button */
.wc-block-components-checkout-place-order-button,
.wc-block-checkout__actions .wc-block-components-button {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 14px 28px;
    font-family: var(--font-heading) !important;
    font-size: .875rem !important;
    font-weight: 600 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #fff !important;
    border-radius: var(--radius) !important;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition) !important;
}
.wc-block-components-checkout-place-order-button:hover,
.wc-block-checkout__actions .wc-block-components-button:hover {
    background: var(--primary-dark) !important;
    border-color: var(--primary-dark) !important;
}

/* Checkout order summary (right column) */
.wc-block-checkout-order-summary-cart-items {
    padding: 0;
}
.wc-block-components-order-summary__item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
    font-size: .875rem;
}
.wc-block-components-order-summary__item:last-child { border-bottom: 1px solid var(--border); }
.wc-block-components-order-summary-item__image img {
    width: 52px;
    height: 52px;
    object-fit: contain;
    background: var(--lighter-bg);
    border-radius: 4px;
    padding: 4px;
}
.wc-block-components-order-summary-item__full-description { flex: 1; }
.wc-block-components-order-summary-item__name {
    font-family: var(--font-heading);
    font-size: .85rem;
    font-weight: 600;
    color: var(--body);
    display: block;
    margin-bottom: 3px;
}
.wc-block-components-order-summary-item__variation {
    font-size: .78rem;
    color: var(--muted);
    display: block;
}
.wc-block-components-order-summary-item__individual-prices {
    font-family: var(--font-heading);
    font-size: .85rem;
    font-weight: 600;
    color: var(--body);
    white-space: nowrap;
}

/* Summary heading */
.wc-block-checkout__order-summary,
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-panel__button {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--heading);
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    margin: 0;
    background: var(--lighter-bg);
    width: 100%;
    text-align: left;
    border-top: none;
    border-left: none;
    border-right: none;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* ---- Classic cart/checkout fallback (if blocks ever replaced) ---- */
.woocommerce-cart table.shop_table,
.woocommerce-checkout table.shop_table {
    border-collapse: collapse;
    width: 100%;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    font-size: .9rem;
}
.woocommerce-cart table.shop_table th,
.woocommerce-checkout table.shop_table th {
    background: var(--lighter-bg);
    font-family: var(--font-heading);
    font-size: .72rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 12px 16px;
    color: var(--muted);
    border-bottom: 1px solid var(--border);
    text-align: left;
}
.woocommerce-cart table.shop_table td,
.woocommerce-checkout table.shop_table td {
    padding: 16px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}
.woocommerce-cart .cart_totals,
.woocommerce-checkout .order-total {
    background: var(--lighter-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
}
.woocommerce-cart .cart_totals h2 { font-size: 1.1rem; margin-bottom: 20px; }

/* ---- Responsive ---- */
@media (max-width: 900px) {
    .wp-block-woocommerce-filled-cart-block,
    .wp-block-woocommerce-checkout.wc-block-checkout {
        grid-template-columns: 1fr;
    }
    .wp-block-woocommerce-cart-totals-block,
    .wp-block-woocommerce-checkout-totals-block {
        position: static;
    }
    .wc-block-cart-items__row {
        grid-template-columns: 64px 1fr auto;
        grid-template-rows: auto auto;
    }
}
@media (max-width: 560px) {
    .wp-block-woocommerce-checkout-fields-block { padding: 20px 16px; }
    .wc-block-cart-items__row {
        grid-template-columns: 56px 1fr;
    }
}

/* ==========================================================================
   NOTICES
   ========================================================================== */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
    padding: 14px 20px;
    border-radius: var(--radius);
    margin-bottom: 20px;
    font-size: .9rem;
    border: none;
    list-style: none;
}
.woocommerce-message { background: #e8f5e9; color: #2e7d32; border-left: 4px solid #4caf50; display: flex; align-items: center; gap: 16px; }
.woocommerce-error   { background: #ffebee; color: #c62828; border-left: 4px solid #f44336; }

.woocommerce-message a.button,
.woocommerce-message .button {
    padding: 7px 14px;
    font-size: .75rem;
    flex-shrink: 0;
    line-height: 1;
}

/* ==========================================================================
   REVIEWS
   ========================================================================== */
.woocommerce-Reviews { max-width: 720px; }

.woocommerce-Reviews-title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 24px;
}

/* Star rating widget label */
#review_form_wrapper .comment-form-rating label {
    font-family: var(--font-heading);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    display: block;
    margin-bottom: 8px;
}
/* Hide the original <select> — WC JS replaces it with p.stars */
#review_form_wrapper .comment-form-rating select { display: none; }
/* Keep focus styles in case JS fails and select is shown */
#review_form_wrapper .comment-form-rating select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* Text fields */
#review_form_wrapper .comment-form-comment label,
#review_form_wrapper .comment-form-author label,
#review_form_wrapper .comment-form-email label {
    font-family: var(--font-heading);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    display: block;
    margin-bottom: 5px;
}
#review_form_wrapper .comment-form-comment textarea,
#review_form_wrapper .comment-form-author input,
#review_form_wrapper .comment-form-email input {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: .9rem;
    color: var(--body);
    background: #fff;
    box-sizing: border-box;
}
#review_form_wrapper .comment-form-comment textarea:focus,
#review_form_wrapper .comment-form-author input:focus,
#review_form_wrapper .comment-form-email input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}
#review_form_wrapper .comment-form-comment textarea { height: 140px; resize: vertical; }

/* Layout: two-column name/email row */
#review_form_wrapper #commentform {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
#review_form_wrapper .comment-form-author,
#review_form_wrapper .comment-form-email { flex: 1; margin: 0; }
#review_form_wrapper .comment-form-author + .comment-form-email {
    /* pair them in a row via a wrapper — handled below by targeting adjacent siblings */
}

/* Notes & required */
#review_form_wrapper .comment-notes { font-size: .8rem; color: var(--muted); margin: 0; }
#review_form_wrapper .required { color: var(--primary); }

/* Submit button */
#review_form_wrapper .form-submit { margin: 0; }
#review_form_wrapper .form-submit #submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 28px;
    font-family: var(--font-heading);
    font-size: .875rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    background: var(--primary);
    color: #fff;
    border: 2px solid var(--primary);
    border-radius: var(--radius);
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition);
}
#review_form_wrapper .form-submit #submit:hover {
    background: var(--primary-dark);
    border-color: var(--primary-dark);
}

/* Cookies consent checkbox row */
#review_form_wrapper .comment-form-cookies-consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: .8rem;
    color: var(--muted);
    margin: 0;
}
#review_form_wrapper .comment-form-cookies-consent input { margin-top: 2px; flex-shrink: 0; }

/* ---- Empty cart ---- */
.wp-block-woocommerce-empty-cart-block {
    text-align: center;
    padding: 0 24px 64px;
    max-width: 860px;
    margin: 0 auto;
}

/* Hide WooCommerce's crying face icon entirely */
.wc-block-cart__empty-cart__title.with-empty-cart-icon::before {
    content: '' !important;
    display: block !important;
    width: 72px !important;
    height: 72px !important;
    margin: 0 auto 20px !important;
    background: var(--lighter-bg) !important;
    border-radius: 50% !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23005490' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: 36px 36px !important;
    font-size: 0 !important;
    color: transparent !important;
}
.wc-block-cart__empty-cart__title.with-empty-cart-icon .wc-block-cart__empty-cart__icon,
.wc-block-cart__empty-cart__title.with-empty-cart-icon svg {
    display: none !important;
}

.wc-block-cart__empty-cart__title {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--heading);
    margin-bottom: 8px;
}

.wp-block-woocommerce-empty-cart-block .wp-block-separator {
    margin: 24px auto;
    border-color: var(--border);
    opacity: 1;
}

.wp-block-woocommerce-empty-cart-block h2:not(.wc-block-cart__empty-cart__title) {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--heading);
    margin-bottom: 24px;
    text-transform: uppercase;
    letter-spacing: .05em;
}

/* ---- WooCommerce Blocks product tiles (empty cart / New in Store) ---- */
.wp-block-woocommerce-empty-cart-block .products {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-top: 0;
    text-align: left;
}

/* Ensure View Product button has white text */
.wp-block-woocommerce-empty-cart-block .btn-primary,
.wp-block-woocommerce-empty-cart-block .btn-primary:visited {
    color: #fff !important;
}

/* Stack buttons vertically — cards are too narrow for side-by-side */
.wp-block-woocommerce-empty-cart-block .product-card-actions {
    flex-direction: column;
}
.wp-block-woocommerce-empty-cart-block .product-card-actions .btn {
    flex: unset;
    width: 100%;
}

@media (max-width: 900px) {
    .wp-block-woocommerce-empty-cart-block .products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
    .wp-block-woocommerce-empty-cart-block .products { grid-template-columns: 1fr; }
}

/* ---- WooCommerce Blocks — cart/checkout submit button ---- */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-add-to-cart a,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-add-to-cart button,
.wc-block-components-button.contained,
.wc-block-cart__submit-button,
.wp-element-button.wc-block-cart__submit-button {
    background-color: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #fff !important;
    font-family: var(--font-heading) !important;
    font-size: .875rem !important;
    font-weight: 600 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    border-radius: var(--radius) !important;
    padding: 14px 28px !important;
    transition: background var(--transition), border-color var(--transition) !important;
}

.wc-block-components-button.contained:hover,
.wc-block-cart__submit-button:hover,
.wp-element-button.wc-block-cart__submit-button:hover {
    background-color: var(--primary-dark) !important;
    border-color: var(--primary-dark) !important;
    color: #fff !important;
}

/* ==========================================================================
   MY ACCOUNT — LOGIN, REGISTER, LOST PASSWORD, DASHBOARD
   ========================================================================== */

/* Page layout */
/* Account dashboard (logged in) — sidebar nav + content */
body.logged-in .woocommerce-account .woocommerce {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 40px;
    padding: 40px 0 80px;
}
body.logged-in .woocommerce-account .woocommerce > .woocommerce-notices-wrapper { grid-column: 1 / -1; }

/* Login / forgot password pages — no sidebar, just centered content */
body:not(.logged-in) .woocommerce-account .woocommerce {
    padding: 40px 0 80px;
}

/* ---- Custom login wrap (theme template override) ---- */
.camsco-login-wrap {
    max-width: 520px;
    margin: 0 auto;
    width: 100%;
}
.camsco-login-wrap--two-col {
    max-width: 880px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
}

/* Login / Register card */
.camsco-login-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 36px 40px;
    width: 100%;
}

.camsco-login-heading {
    font-family: var(--font-heading);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--body);
    text-align: center;
    margin-bottom: 28px;
}

/* Forms inside cards — transparent, no double border */
.woocommerce-form-login,
.woocommerce-form-register {
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
}

/* Lost password / Reset password pages */
.woocommerce-ResetPassword {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 36px 40px;
    max-width: 520px;
    margin: 0 auto;
    width: 100%;
}
.woocommerce-ResetPassword h2 {
    font-family: var(--font-heading);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--body);
    text-align: center;
    margin-bottom: 24px;
}

.lost_password { margin-top: 16px; font-size: .85rem; text-align: center; }
.lost_password a { color: var(--primary); text-decoration: none; }
.lost_password a:hover { text-decoration: underline; }

.woocommerce-form__label,
.woocommerce-form-login .woocommerce-form__label {
    font-family: var(--font-heading);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    display: block;
    margin-bottom: 5px;
}

.woocommerce-form-login input[type="text"],
.woocommerce-form-login input[type="password"],
.woocommerce-form-login input[type="email"],
.woocommerce-form-register input[type="text"],
.woocommerce-form-register input[type="password"],
.woocommerce-form-register input[type="email"],
.woocommerce-ResetPassword .woocommerce-Input,
.woocommerce-ResetPassword input[type="text"],
.woocommerce-ResetPassword input[type="email"],
.woocommerce-account .woocommerce-Input--text,
.woocommerce-account input.input-text {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: .9rem;
    color: var(--body);
    background: #fff;
    box-sizing: border-box;
    transition: border-color var(--transition), box-shadow var(--transition);
    float: none;
}

.woocommerce-form-login input[type="text"]:focus,
.woocommerce-form-login input[type="password"]:focus,
.woocommerce-form-login input[type="email"]:focus,
.woocommerce-form-register input[type="text"]:focus,
.woocommerce-form-register input[type="password"]:focus,
.woocommerce-form-register input[type="email"]:focus,
.woocommerce-ResetPassword .woocommerce-Input:focus,
.woocommerce-ResetPassword input[type="text"]:focus,
.woocommerce-ResetPassword input[type="email"]:focus,
.woocommerce-account input.input-text:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,84,144,.12);
}

/* Reset WooCommerce half-width row floats */
.woocommerce-account .woocommerce-form-row,
.woocommerce-account .form-row {
    float: none !important;
    width: 100% !important;
    padding: 0 !important;
    margin-bottom: 16px;
}

.woocommerce-ResetPassword p { margin-bottom: 16px; font-size: .9rem; color: var(--muted); }

.woocommerce-form-group,
.woocommerce-form__label-for-checkbox {
    margin-bottom: 18px;
}

/* Remember me + lost password row */
.woocommerce-form-login .woocommerce-form__label-for-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .85rem;
    color: var(--muted);
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
    margin-bottom: 20px;
}

.woocommerce-LostPassword a,
.lost_password a {
    font-size: .85rem;
    color: var(--primary);
    text-decoration: none;
}
.woocommerce-LostPassword a:hover,
.lost_password a:hover { text-decoration: underline; }

/* Submit buttons */
.woocommerce-form-login__submit,
.woocommerce-form-register__submit,
.woocommerce-ResetPassword button,
.woocommerce-ResetPassword input[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 28px;
    background: var(--primary);
    color: #fff;
    border: 2px solid var(--primary);
    border-radius: var(--radius);
    font-family: var(--font-heading);
    font-size: .875rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition);
    width: 100%;
}
.woocommerce-form-login__submit:hover,
.woocommerce-form-register__submit:hover,
.woocommerce-ResetPassword input[type="submit"]:hover {
    background: var(--primary-dark);
    border-color: var(--primary-dark);
}

/* ---- Account dashboard navigation ---- */
.woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 10px 14px;
    border-radius: var(--radius);
    font-family: var(--font-heading);
    font-size: .82rem;
    font-weight: 600;
    color: var(--body);
    text-decoration: none;
    transition: color var(--transition), background var(--transition);
}

.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
    color: var(--primary);
    background: var(--lighter-bg);
}

/* ---- Account content area ---- */
.woocommerce-MyAccount-content h2 {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 20px;
    color: var(--heading);
}

.woocommerce-MyAccount-content p { font-size: .9rem; line-height: 1.7; }

/* Orders table */
.woocommerce-orders-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
}
.woocommerce-orders-table th {
    background: var(--lighter-bg);
    font-family: var(--font-heading);
    font-size: .72rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 10px 14px;
    color: var(--muted);
    border-bottom: 1px solid var(--border);
    text-align: left;
}
.woocommerce-orders-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}

@media (max-width: 760px) {
    .woocommerce-account .woocommerce { grid-template-columns: 1fr; }
}

/* ── Configurator CTA (ATD tube product page) ────────────────────────────── */
.atd-configurator-cta {
    display: flex;
    align-items: center;
    gap: 14px;
    background: rgba(0,84,144,.05);
    border: 1px solid rgba(0,84,144,.18);
    border-radius: var(--radius);
    padding: 14px 16px;
    margin-bottom: 20px;
    font-size: .875rem;
    color: var(--body);
}
.atd-configurator-cta svg { flex-shrink: 0; color: var(--primary); }
.atd-configurator-cta div { flex: 1; line-height: 1.45; }
.atd-configurator-cta strong { display: block; color: var(--primary); margin-bottom: 2px; }
.atd-configurator-cta .btn { flex-shrink: 0; white-space: nowrap; }

/* ── Call for Pricing ─────────────────────────────────────────────────────── */
.call-for-pricing {
    display: inline-block;
    font-family: var(--font-heading);
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--muted);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 4px 10px;
}
.call-for-pricing-btn {
    display: inline-flex;
    margin-top: 8px;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 900px) {
    body.single-product div.product:not(.product-card) { grid-template-columns: 1fr; gap: 32px; }
    .related.products ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
    .related.products ul.products { grid-template-columns: 1fr; }
    .woocommerce div.product .woocommerce-variation-add-to-cart { flex-direction: column; align-items: stretch; }
    .woocommerce div.product .quantity input[type=number] { width: 100%; }
}
