/* ==========================================================================
   WooCommerce — Shop, Product, Cart, Checkout
   ========================================================================== */

/* Override font for all WooCommerce pages */
.vc-woocommerce,
.vc-woocommerce * {
    --vc-font-family: 'Roboto', sans-serif;
}

/* Cart & Checkout — force Roboto on text elements */
.woocommerce-cart,
.woocommerce-checkout {
    font-family: 'Roboto', sans-serif;
}

.woocommerce-cart h1, .woocommerce-cart h2, .woocommerce-cart h3, .woocommerce-cart h4,
.woocommerce-cart p, .woocommerce-cart a, .woocommerce-cart span, .woocommerce-cart label,
.woocommerce-cart input, .woocommerce-cart button, .woocommerce-cart select, .woocommerce-cart textarea,
.woocommerce-cart td, .woocommerce-cart th, .woocommerce-cart li,
.woocommerce-checkout h1, .woocommerce-checkout h2, .woocommerce-checkout h3, .woocommerce-checkout h4,
.woocommerce-checkout p, .woocommerce-checkout a, .woocommerce-checkout span, .woocommerce-checkout label,
.woocommerce-checkout input, .woocommerce-checkout button, .woocommerce-checkout select, .woocommerce-checkout textarea,
.woocommerce-checkout td, .woocommerce-checkout th, .woocommerce-checkout li {
    font-family: 'Roboto', sans-serif !important;
}

/* ==========================================================================
   Shop Layout — sidebar left + products right on desktop, slide-in on mobile
   ========================================================================== */

.vc-shop-layout {
    display: block;
    width: 100%;
    overflow-x: hidden;
}

.vc-shop-layout__main {
    min-width: 0;
    width: 100%;
}

/* Mobile: sidebar as slide-in panel */
.vc-shop-layout__sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 320px;
    max-width: 92vw;
    height: 100%;
    z-index: 10000;
    background: #fff;
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.15);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    overflow-y: auto;
    padding: 0 1.25rem 2rem;
}

.vc-shop-layout__sidebar.vc-sidebar--open {
    transform: translateX(0);
}

/* Desktop: 2-column grid, sidebar always visible on the left */
@media (min-width: 1024px) {
    .vc-shop-layout {
        display: grid;
        grid-template-columns: 230px 1fr;
        gap: 1.5rem;
        align-items: start;
        max-width: 1200px;
        margin: 0 auto;
        padding: 0 1rem;
    }

    /* Remove inner container constraint so products fill the grid column */
    .vc-shop-layout__main .vc-container {
        max-width: none;
        padding: 0;
        margin: 0;
    }

    .vc-shop-layout__sidebar {
        order: -1;
        position: sticky;
        top: 100px;
        max-height: calc(100vh - 120px);
        overflow-y: auto;
        width: 100%;
        height: auto;
        z-index: auto;
        background: transparent;
        box-shadow: none;
        transform: none;
        transition: none;
        padding: 0;
        scrollbar-width: thin;
        scrollbar-color: #ccc transparent;
    }

    .vc-shop-layout__sidebar::-webkit-scrollbar {
        width: 4px;
    }

    .vc-shop-layout__sidebar::-webkit-scrollbar-thumb {
        background: #ccc;
        border-radius: 2px;
    }
}

/* ==========================================================================
   Filter Panel — shared container
   ========================================================================== */

.vc-filter-panel {
    margin-bottom: 1.5rem;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
}

.vc-filter-panel__title {
    font-family: 'Roboto', sans-serif;
    font-size: 0.875rem;
    font-weight: 600;
    color: #333;
    margin: 0 0 0.625rem;
    padding-bottom: 0;
    border-bottom: none;
    text-transform: none;
    letter-spacing: 0;
}

.vc-shop-layout__sidebar,
.vc-shop-layout__sidebar * {
    font-family: 'Roboto', sans-serif;
}

/* ==========================================================================
   Filter — Search box
   ========================================================================== */

.vc-filter-search {
    display: flex;
    align-items: center;
    gap: 0;
    border: 1px solid #ddd;
    border-radius: 3px;
    overflow: hidden;
    background: #fff;
    transition: border-color var(--vc-transition);
}

.vc-filter-search:focus-within {
    border-color: #999;
    box-shadow: none;
}

.vc-filter-search__input {
    flex: 1;
    min-width: 0;
    padding: 0.5rem 0.75rem;
    background: transparent;
    border: none;
    outline: none;
    color: var(--vc-text-primary);
    font-size: var(--vc-font-size-sm);
    font-family: var(--vc-font-family);
    line-height: 1.4;
}

.vc-filter-search__input::placeholder {
    color: var(--vc-text-secondary);
    opacity: 0.7;
}

.vc-filter-search__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: none;
    border: none;
    color: var(--vc-text-secondary);
    cursor: pointer;
    transition: color var(--vc-transition);
    flex-shrink: 0;
}

.vc-filter-search__btn:hover {
    color: #000;
}

/* ==========================================================================
   Filter — Category Checkbox Tree
   ========================================================================== */

.vc-cat-list {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 300px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #ccc transparent;
}

@media (min-width: 1024px) {
    .vc-cat-list {
        max-height: 400px;
    }
}

.vc-cat-list::-webkit-scrollbar {
    width: 4px;
}

.vc-cat-list::-webkit-scrollbar-track {
    background: transparent;
}

.vc-cat-list::-webkit-scrollbar-thumb {
    background: var(--vc-border);
    border-radius: 2px;
}

.vc-cat-list__item {
    position: relative;
    margin-bottom: 2px;
}

/* Children sub-list */
.vc-cat-list--children {
    margin: 0.125rem 0 0.125rem 0;
    max-height: none;
    overflow-y: visible;
    padding-left: 1.25rem;
    border-left: none;
}

/* Checkbox + label row */
.vc-cat-label {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.2rem 1.75rem 0.2rem 0;
    cursor: pointer;
    border-radius: 0;
    transition: none;
    -webkit-user-select: none;
    user-select: none;
}

.vc-cat-label:hover {
    background: transparent;
}

.vc-cat-checkbox {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    accent-color: #000;
    cursor: pointer;
    margin: 0;
}

.vc-cat-label__text {
    font-size: 0.8125rem;
    color: #333;
    line-height: 1.4;
    flex: 1;
}

.vc-cat-label__count {
    display: none;
}

/* "All" item — slightly bolder */
.vc-cat-list__item--all .vc-cat-label__text {
    font-weight: 600;
}

/* Toggle expand/collapse button for parents */
.vc-cat-toggle {
    position: absolute;
    top: 0;
    right: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    color: #999;
    font-size: 13px;
    font-weight: 700;
    transition: color 0.2s ease;
    line-height: 1;
    padding: 0;
}

.vc-cat-toggle::after {
    content: "+";
    display: block;
    line-height: 1;
}

.vc-cat-list__item--parent.vc-cat-open > .vc-cat-toggle::after {
    content: "\2212"; /* minus sign */
}

.vc-cat-toggle:hover {
    color: #000;
}

/* Active category label highlight */
.vc-cat-checkbox:checked + .vc-cat-label__text {
    color: #000;
    font-weight: 600;
}

/* ==========================================================================
   Filter — Dual Price Slider
   ========================================================================== */

.vc-price-slider__track-wrap {
    position: relative;
    height: 24px;           /* tall enough for the handle hit-area */
    margin: 0.5rem 0 0.75rem;
    display: flex;
    align-items: center;
}

.vc-price-slider__track,
.vc-price-slider__fill {
    position: absolute;
    left: 0;
    right: 0;
    height: 4px;
    border-radius: 2px;
    pointer-events: none;
}

.vc-price-slider__track {
    background: #ddd;
}

.vc-price-slider__fill {
    background: #000;
}

/* Both range inputs sit on top of each other */
.vc-price-slider__input {
    position: absolute;
    left: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
    margin: 0;
    padding: 0;
    -webkit-appearance: none;
    appearance: none;
    background: transparent;
    pointer-events: none;   /* track is non-interactive; only thumbs respond */
}

/* Both sliders need same z-index so neither fully blocks the other */
.vc-price-slider__input--min {
    z-index: 3;
}

.vc-price-slider__input--max {
    z-index: 4;
}

/* Show thumb via a pseudo-overlay technique using a sibling div approach.
   We use the ::after of the track-wrap to render visible handles. */

/* Visible thumb — pointer-events: auto so each thumb is individually draggable */
.vc-price-slider__input::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid #000;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
    cursor: pointer;
    pointer-events: auto;
    position: relative;
    z-index: 10;
    transition: transform 0.15s ease;
    margin-top: -6px;
}

.vc-price-slider__input::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid #000;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
    cursor: pointer;
    pointer-events: auto;
    position: relative;
    z-index: 10;
    transition: transform 0.15s ease;
}

.vc-price-slider__input:focus-visible::-webkit-slider-thumb {
    outline: 2px solid #333;
    outline-offset: 2px;
    box-shadow: none;
}

.vc-price-slider__input::-webkit-slider-thumb:active {
    transform: scale(1.2);
}

.vc-price-slider__input::-moz-range-thumb:active {
    transform: scale(1.2);
}

/* Make inputs visible so thumbs render — track stays transparent */
.vc-price-slider__input {
    opacity: 1;
    background: transparent;
    -webkit-appearance: none;
    appearance: none;
}

/* Webkit: transparent track so our custom track divs show through */
.vc-price-slider__input::-webkit-slider-runnable-track {
    background: transparent;
    height: 4px;
}

.vc-price-slider__input::-moz-range-track {
    background: transparent;
    height: 4px;
}

/* Price label row */
.vc-price-slider__display {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    font-size: 0.8125rem;
    color: #333;
    font-weight: 400;
}

.vc-price-slider__label {
    display: inline-flex;
    align-items: center;
    gap: 1px;
}

.vc-price-slider__sep {
    color: var(--vc-text-secondary);
    flex: 1;
    text-align: center;
}

/* Apply button */
.vc-price-slider__apply {
    display: inline-block;
    padding: 0.375rem 1.25rem;
    background: #000;
    color: #fff;
    border: none;
    border-radius: 3px;
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    font-family: 'Roboto', sans-serif;
    transition: background 0.2s ease;
    text-align: center;
    width: auto;
}

.vc-price-slider__apply:hover {
    background: #333;
    transform: none;
}

.vc-price-slider__apply:focus-visible {
    outline: 2px solid #333;
    outline-offset: 2px;
}

/* ==========================================================================
   Filter — Clear all link
   ========================================================================== */

.vc-filter-panel--clear {
    text-align: left;
    padding: 0.75rem 0 0;
    margin-bottom: 0;
}

.vc-filter-clear {
    font-size: 0.75rem;
    color: #666;
    text-decoration: underline;
    transition: color 0.2s ease;
}

.vc-filter-clear:hover {
    color: #000;
}

/* Legacy widget styles — kept for graceful fallback if widgets are ever re-enabled */
.vc-shop-layout__sidebar .widget {
    margin-bottom: 1.5rem;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
}

.vc-shop-layout__sidebar .widget-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--vc-text-primary);
    margin-bottom: 0.75rem;
    padding-bottom: 0;
    border-bottom: none;
}

.vc-shop-layout__sidebar .widget ul {
    list-style: none;
    padding: 0;
}

.vc-shop-layout__sidebar .widget ul li {
    margin-bottom: 0.375rem;
}

.vc-shop-layout__sidebar .widget ul li a {
    display: block;
    padding: 0.375rem 0;
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-secondary);
}

.vc-shop-layout__sidebar .widget ul li a:hover {
    color: var(--vc-accent);
}

/* Shop header (result count + ordering) */
.woocommerce-result-count {
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-secondary);
    margin-bottom: 0;
}

.woocommerce-ordering {
    margin-bottom: 0;
}

.woocommerce-ordering select {
    width: auto;
    min-width: 200px;
    background: var(--vc-bg-input);
    color: var(--vc-text-primary);
    border-color: var(--vc-border);
}

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
    margin-bottom: 1rem;
}

/* Shop toolbar */
.woocommerce-notices-wrapper + .woocommerce-result-count,
.woocommerce-result-count {
    float: left;
    line-height: 2.5;
}

.woocommerce-ordering {
    float: right;
}

/* Product grid in shop */
.woocommerce ul.products {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    list-style: none;
    padding: 0;
    clear: both;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
    display: none;
}

.woocommerce ul.products li.product,
.woocommerce ul.products[class*="columns-"] li.product {
    float: none !important;
    clear: none !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0;
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    overflow: hidden;
    box-shadow: var(--vc-shadow-sm);
    transition: box-shadow var(--vc-transition), transform var(--vc-transition), border-color var(--vc-transition);
    display: flex;
    flex-direction: column;
}

.woocommerce ul.products li.product:hover {
    box-shadow: var(--vc-shadow-lg);
    border-color: var(--vc-border-dark);
    transform: translateY(-2px);
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
    display: block;
    text-decoration: none;
    color: var(--vc-text-primary);
}

/* Product card image in shop */
.woocommerce ul.products li.product .vc-product-card__image {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--vc-bg-section);
    position: relative;
    width: 100%;
}

.woocommerce ul.products li.product .vc-product-card__image img,
.woocommerce ul.products li.product .vc-product-card__image img.wp-post-image {
    width: 100% !important;
    height: 100% !important;
    max-height: none;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.woocommerce ul.products li.product:hover .vc-product-card__image img {
    transform: scale(1.05);
}

/* Sale badge in shop (both WooCommerce default and custom) */
.woocommerce ul.products li.product .onsale,
.woocommerce ul.products li.product .vc-product-card__badge--sale,
.woocommerce span.onsale {
    position: absolute;
    top: 0.5rem;
    left: 0.5rem;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    font-size: 11px;
    font-weight: 700;
    padding: 0.25rem 0.625rem;
    border-radius: var(--vc-radius-sm);
    text-transform: uppercase;
    z-index: 2;
    min-height: auto;
    min-width: auto;
    line-height: 1.4;
    margin: 0;
}

/* Hide duplicate default WooCommerce sale badge (we use our custom one inside the image wrapper) */
.woocommerce ul.products li.product > .onsale {
    display: none;
}

/* Product title in shop */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: var(--vc-font-size-sm);
    font-weight: 600;
    padding: 0.875rem 1rem 0.25rem;
    margin: 0;
    color: var(--vc-white);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.4;
    min-height: 2.8em; /* 2 lines * 1.4 line-height */
}

/* Product price in shop */
.woocommerce ul.products li.product .price {
    padding: 0.25rem 1rem;
    font-size: var(--vc-font-size-base);
    font-weight: 700;
    color: var(--vc-text-primary);
    margin-bottom: 0;
    display: block;
    overflow: visible;
    white-space: nowrap;
    line-height: 1.4;
}

.woocommerce ul.products li.product .price .woocommerce-Price-amount {
    display: inline;
    font-size: inherit;
}

.woocommerce ul.products li.product .price .woocommerce-Price-currencySymbol {
    font-size: inherit;
}

.woocommerce ul.products li.product .price del {
    color: var(--vc-text-secondary);
    font-weight: 400;
    font-size: var(--vc-font-size-sm);
}

.woocommerce ul.products li.product .price ins {
    text-decoration: none;
    color: var(--vc-accent);
}

/* Add to cart button in shop */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.product_type_simple,
.woocommerce ul.products li.product a.product_type_variable {
    display: block;
    margin: auto 1rem 1rem;
    padding: 0.5rem 1rem;
    text-align: center;
    background: var(--vc-accent);
    color: var(--vc-always-white) !important;
    border: none;
    border-radius: var(--vc-radius-sm);
    font-size: var(--vc-font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--vc-transition), transform var(--vc-transition);
    font-family: var(--vc-font-family);
    text-decoration: none;
    line-height: 1.5;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.add_to_cart_button:hover {
    background: var(--vc-accent-hover);
    transform: translateY(-1px);
}

/* "Select Options" button for variable products */
.woocommerce ul.products li.product a.product_type_variable,
.woocommerce ul.products li.product a.button.product_type_external {
    background: var(--vc-bg-section);
    color: var(--vc-text-primary) !important;
    border: 1px solid var(--vc-border);
}

.woocommerce ul.products li.product a.product_type_variable:hover,
.woocommerce ul.products li.product a.button.product_type_external:hover {
    background: var(--vc-accent);
    color: var(--vc-always-white) !important;
    border-color: var(--vc-accent);
}

/* Out of stock badge on product image */
.vc-product-card__badge--out {
    background: var(--vc-medium-gray);
    color: var(--vc-always-white);
}

/* Out of stock button style */
.woocommerce ul.products li.product a.vc-btn--out-of-stock {
    background: var(--vc-bg-section) !important;
    color: var(--vc-text-secondary) !important;
    cursor: not-allowed;
    opacity: 0.7;
}

.woocommerce ul.products li.product a.vc-btn--out-of-stock:hover {
    background: var(--vc-bg-section) !important;
    transform: none;
}

/* Stock & variation meta wrapper */
.vc-product-card__meta {
    padding: 0.25rem 1rem 0;
}

/* Stock status on product cards */
.vc-product-card__stock {
    font-size: var(--vc-font-size-xs);
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.vc-product-card__stock--in {
    color: var(--vc-success);
}

.vc-product-card__stock--low {
    color: var(--vc-warning);
}

.vc-product-card__stock--out {
    color: var(--vc-accent);
}

/* Variation list on product cards */
.vc-product-card__var-list {
    list-style: none;
    padding: 0;
    margin: 0.25rem 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    max-height: 4.5rem;
    overflow: hidden;
}

.vc-product-card__var-item {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.125rem 0.5rem;
    background: var(--vc-bg-input);
    border: 1px solid var(--vc-border);
    border-radius: 999px;
    font-size: 10px;
    line-height: 1.4;
    white-space: nowrap;
}

.vc-product-card__var-item--low {
    border-color: var(--vc-warning);
}

.vc-product-card__var-name {
    color: var(--vc-text-primary);
    font-weight: 500;
}

.vc-product-card__var-qty {
    color: var(--vc-text-secondary);
    font-weight: 600;
    font-size: 9px;
    background: var(--vc-bg-section);
    padding: 0 0.3rem;
    border-radius: 999px;
    min-width: 1rem;
    text-align: center;
}

.vc-product-card__var-item--low .vc-product-card__var-qty {
    color: var(--vc-warning);
}

/* Loading state for add to cart */
.woocommerce ul.products li.product .button.loading {
    opacity: 0.7;
    pointer-events: none;
}

.woocommerce ul.products li.product a.added_to_cart {
    display: block;
    text-align: center;
    font-size: var(--vc-font-size-xs);
    padding: 0.25rem 1rem 0.75rem;
    color: var(--vc-success);
    font-weight: 600;
}

/* Single Product */
.woocommerce div.product {
    margin-bottom: 2rem;
}

.woocommerce div.product div.images {
    float: none;
    width: 100%;
    margin-bottom: 1.5rem;
}

.woocommerce div.product div.images img {
    border-radius: var(--vc-radius);
}

.woocommerce div.product div.summary {
    float: none;
    width: 100%;
    color: var(--vc-text-primary);
}

.woocommerce div.product .product_title {
    font-size: var(--vc-font-size-2xl);
    font-weight: 700;
    color: var(--vc-white);
    margin-bottom: 0.75rem;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    font-size: var(--vc-font-size-xl);
    font-weight: 700;
    color: var(--vc-text-primary);
    margin-bottom: 1rem;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
    text-decoration: none;
    color: var(--vc-accent);
}

.woocommerce div.product .woocommerce-product-details__short-description {
    margin-bottom: 1.5rem;
    line-height: 1.7;
    color: var(--vc-text-secondary);
}

/* Add to cart form */
.woocommerce div.product form.cart {
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.woocommerce div.product form.cart .quantity {
    margin-right: 0;
}

.woocommerce .quantity .qty {
    width: 70px;
    text-align: center;
    padding: 0.625rem;
    background: var(--vc-bg-input);
    color: var(--vc-text-primary);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
}

.woocommerce div.product form.cart .single_add_to_cart_button {
    padding: 0.75rem 2rem;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    border: none;
    border-radius: var(--vc-radius);
    font-size: var(--vc-font-size-base);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--vc-transition);
    font-family: var(--vc-font-family);
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover {
    background: var(--vc-accent-hover);
}

/* Variation select */
.woocommerce div.product form.cart .variations {
    width: 100%;
    margin-bottom: 1rem;
    border-collapse: collapse;
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
    border: none;
    padding: 0.5rem 0;
    vertical-align: middle;
}

.woocommerce div.product form.cart .variations label {
    font-weight: 600;
    margin-bottom: 0;
}

.woocommerce div.product form.cart .variations select {
    min-width: 200px;
}

/* Product meta */
.woocommerce div.product .product_meta {
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-secondary);
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--vc-border);
}

.woocommerce div.product .product_meta > span {
    display: block;
    margin-bottom: 0.375rem;
}

.woocommerce div.product .product_meta a {
    color: var(--vc-accent);
}

/* Product tabs */
.woocommerce div.product .woocommerce-tabs {
    margin-top: 2rem;
    clear: both;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
    list-style: none;
    padding: 0;
    margin: 0 0 -1px;
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--vc-border);
    overflow-x: auto;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after {
    display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    border: none;
    background: none;
    margin: 0;
    padding: 0;
    border-radius: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 0.75rem 1.25rem;
    font-size: var(--vc-font-size-sm);
    font-weight: 600;
    color: var(--vc-text-secondary);
    background: var(--vc-bg-card);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all var(--vc-transition);
    white-space: nowrap;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--vc-white);
    background: var(--vc-bg-body);
    border-bottom-color: var(--vc-accent);
}

.woocommerce div.product .woocommerce-tabs .panel {
    padding: 1.5rem;
    background: var(--vc-bg-body);
    color: var(--vc-text-primary);
    border: none;
    margin: 0;
    border-radius: 0;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
    font-size: var(--vc-font-size-xl);
    margin-bottom: 1rem;
}

/* Related products / upsells */
.woocommerce .related.products,
.woocommerce .upsells.products {
    margin-top: 3rem;
    clear: both;
}

.woocommerce .related.products > h2,
.woocommerce .upsells.products > h2 {
    font-size: var(--vc-font-size-xl);
    margin-bottom: 1.5rem;
}

/* ==========================================================================
   Cart — Clean List Layout
   ========================================================================== */

.vc-cart-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
}

.vc-cart-layout__items {
    min-width: 0;
}

/* All cart items inside one card container */
.vc-cart-items {
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    overflow: hidden;
}

/* Individual cart item row */
.vc-cart-item {
    position: relative;
    display: grid;
    grid-template-columns: 80px 1fr auto;
    grid-template-areas: "image details actions";
    gap: 0 1rem;
    padding: 1.25rem;
    padding-right: 2.5rem;
    align-items: center;
    border-bottom: 1px solid var(--vc-border);
}

.vc-cart-item:last-child {
    border-bottom: none;
}

.vc-cart-item__image {
    grid-area: image;
}

.vc-cart-item__image a {
    display: block;
}

.vc-cart-item__image img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: var(--vc-radius-sm);
    background: var(--vc-bg-section);
    display: block;
}

.vc-cart-item__details {
    grid-area: details;
    min-width: 0;
}

.vc-cart-item__name {
    margin-bottom: 0.25rem;
}

.vc-cart-item__name a {
    color: var(--vc-text-primary);
    font-weight: 600;
    font-size: var(--vc-font-size-sm);
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.vc-cart-item__name a:hover {
    color: var(--vc-accent);
}

.vc-cart-item__details .variation {
    font-size: var(--vc-font-size-xs);
    color: var(--vc-text-secondary);
    margin-top: 0.125rem;
}

.vc-cart-item__details .variation dt {
    display: inline;
    font-weight: 600;
}

.vc-cart-item__details .variation dd {
    display: inline;
    margin: 0;
    color: var(--vc-text-primary);
}

.vc-cart-item__details .variation dd p {
    display: inline;
    margin: 0;
}

.vc-cart-item__details .variation dt::after {
    content: ": ";
}

.vc-cart-item__unit-price {
    font-size: var(--vc-font-size-xs);
    color: var(--vc-text-secondary);
    margin-top: 0.25rem;
}

/* Actions column: quantity + subtotal stacked */
.vc-cart-item__actions {
    grid-area: actions;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.5rem;
}

.vc-cart-item__subtotal {
    font-weight: 700;
    font-size: var(--vc-font-size-base);
    color: var(--vc-text-primary);
    white-space: nowrap;
}

/* Remove button — absolute top-right corner */
.vc-cart-item__remove {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
}

.vc-cart-item__remove .remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: transparent;
    color: var(--vc-text-secondary);
    font-size: 1rem;
    line-height: 1;
    text-decoration: none;
    transition: all var(--vc-transition);
    opacity: 0.4;
}

.vc-cart-item:hover .vc-cart-item__remove .remove {
    opacity: 1;
}

.vc-cart-item__remove .remove:hover {
    background: var(--vc-accent);
    color: var(--vc-always-white);
    opacity: 1;
}

/* Quantity wrapper (± buttons) */
.vc-qty-wrapper {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
    overflow: hidden;
    flex-shrink: 0;
}

.vc-qty-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--vc-bg-section);
    border: none;
    color: var(--vc-text-primary);
    font-size: 1rem;
    cursor: pointer;
    transition: background var(--vc-transition);
    font-family: var(--vc-font-family);
    padding: 0;
}

.vc-qty-btn:hover {
    background: var(--vc-accent);
    color: var(--vc-always-white);
}

.vc-qty-wrapper .qty {
    width: 40px;
    height: 32px;
    text-align: center;
    border: none;
    background: var(--vc-bg-input);
    color: var(--vc-text-primary);
    font-size: var(--vc-font-size-sm);
    font-family: var(--vc-font-family);
    -moz-appearance: textfield;
    padding: 0;
}

.vc-qty-wrapper .qty::-webkit-inner-spin-button,
.vc-qty-wrapper .qty::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Cart actions (coupon + update) */
.vc-cart-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 1rem;
    padding: 1rem 1.25rem;
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    flex-wrap: wrap;
}

.vc-cart-coupon {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex: 1;
    min-width: 0;
}

.vc-cart-coupon .input-text {
    max-width: 200px;
    flex: 1;
}

/* Cart summary sidebar */
.vc-cart-layout__summary {
    position: sticky;
    top: 100px;
}

.vc-cart-layout__summary .cart-collaterals {
    margin-top: 0;
}

.woocommerce .cart_totals,
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
    float: none;
    width: 100%;
    max-width: none;
    margin-left: 0;
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    padding: 1.5rem;
}

.woocommerce .cart_totals h2 {
    font-size: var(--vc-font-size-lg);
    color: var(--vc-white);
    margin: 0 0 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--vc-border);
}

.woocommerce .cart_totals table,
.woocommerce .cart_totals table.shop_table {
    border: none;
    border-collapse: collapse;
    background: transparent;
    table-layout: auto;
    width: 100%;
}

.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td,
.woocommerce .cart_totals table.shop_table th,
.woocommerce .cart_totals table.shop_table td {
    border: none;
    border-bottom: 1px solid var(--vc-border);
    color: var(--vc-text-primary);
    padding: 0.75rem 0;
    font-size: var(--vc-font-size-sm);
}

.woocommerce .cart_totals table.shop_table th,
.woocommerce .cart_totals .shop_table th {
    font-weight: 500;
    color: var(--vc-text-secondary);
    text-align: left;
    padding-right: 1rem;
    background: transparent;
    text-transform: none;
    letter-spacing: 0;
    font-size: var(--vc-font-size-sm);
    vertical-align: top;
    white-space: nowrap;
}

.woocommerce .cart_totals table.shop_table td,
.woocommerce .cart_totals .shop_table td {
    text-align: right;
    font-size: var(--vc-font-size-sm);
    vertical-align: top;
    word-break: normal;
}

/* Shipping row — left-align radio buttons and methods */
.woocommerce .cart_totals .shipping td {
    text-align: left;
    font-size: var(--vc-font-size-sm);
    line-height: 1.6;
}

.woocommerce .cart_totals .shipping td ul#shipping_method {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce .cart_totals .shipping td ul#shipping_method li {
    margin-bottom: 0.375rem;
}

.woocommerce .cart_totals .shipping td ul#shipping_method li label {
    font-size: var(--vc-font-size-sm);
    cursor: pointer;
}

.woocommerce .cart_totals .shipping td ul#shipping_method li input[type="radio"] {
    margin-right: 0.375rem;
}

.woocommerce .cart_totals .shipping td > p {
    display: none;
}

.woocommerce .cart_totals .shipping td .woocommerce-shipping-calculator {
    margin-top: 0.5rem;
}

.woocommerce .cart_totals .shipping td .woocommerce-shipping-calculator .shipping-calculator-button {
    font-size: var(--vc-font-size-sm);
    color: var(--vc-accent);
    text-decoration: none;
}

.woocommerce .cart_totals .shipping td .woocommerce-shipping-calculator .shipping-calculator-button:hover {
    text-decoration: underline;
}

.woocommerce .cart_totals table.shop_table tr.order-total th,
.woocommerce .cart_totals table.shop_table tr.order-total td {
    border-bottom: none;
    padding-top: 0.75rem;
    font-size: var(--vc-font-size-base);
    font-weight: 700;
    color: var(--vc-white);
}

.woocommerce .cart_totals .wc-proceed-to-checkout {
    margin-top: 1.25rem;
}

.woocommerce .cart_totals .wc-proceed-to-checkout .checkout-button {
    display: block;
    width: 100%;
    padding: 1rem 1.5rem;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    border: none;
    border-radius: var(--vc-radius);
    font-size: var(--vc-font-size-base);
    font-weight: 700;
    text-align: center;
    cursor: pointer;
    transition: background var(--vc-transition);
    font-family: var(--vc-font-family);
    line-height: 1.4;
}

.woocommerce .cart_totals .wc-proceed-to-checkout .checkout-button:hover {
    background: var(--vc-accent-hover);
}

/* Shop table fallback (order details, etc.) */
.woocommerce table.shop_table {
    width: 100%;
    border-collapse: collapse;
    background: var(--vc-bg-card);
    color: var(--vc-text-primary);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    overflow: hidden;
}

.woocommerce table.shop_table th {
    background: var(--vc-bg-section);
    color: var(--vc-white);
    font-weight: 600;
    font-size: var(--vc-font-size-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 1rem;
    text-align: left;
    border-bottom: 1px solid var(--vc-border);
}

.woocommerce table.shop_table td {
    padding: 1rem;
    border-bottom: 1px solid var(--vc-border);
    color: var(--vc-text-primary);
    vertical-align: middle;
}

/* ==========================================================================
   Checkout — Numbered Sections + Sidebar
   ========================================================================== */

.vc-checkout-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 2rem;
    align-items: start;
}

.vc-checkout-layout__main {
    min-width: 0;
}

.vc-checkout-layout__sidebar {
    position: sticky;
    top: 100px;
}

/* Checkout sections */
.vc-checkout-section {
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    margin-bottom: 1.5rem;
    overflow: hidden;
}

.vc-checkout-section__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--vc-border);
}

.vc-checkout-section__header h3 {
    font-size: var(--vc-font-size-lg);
    color: var(--vc-white);
    margin: 0;
}

.vc-checkout-section__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    font-weight: 700;
    font-size: var(--vc-font-size-sm);
    flex-shrink: 0;
}

.vc-checkout-section__body {
    padding: 1.5rem;
}

/* Checkout sidebar — order summary */
.vc-checkout-summary {
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    padding: 1.5rem;
    box-shadow: 0 1px 8px rgba(0, 0, 0, 0.04);
}

.vc-checkout-summary__title {
    font-size: var(--vc-font-size-lg);
    color: var(--vc-white);
    margin: 0 0 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--vc-border);
}

.vc-checkout-summary__items {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--vc-border);
}

.vc-checkout-summary__item {
    display: grid;
    grid-template-columns: 60px 1fr auto;
    gap: 0.75rem;
    align-items: center;
}

.vc-checkout-summary__item-image {
    position: relative;
    width: 60px;
    height: 60px;
}

.vc-checkout-summary__item-image img {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border-radius: var(--vc-radius-sm);
}

.vc-checkout-summary__item-qty {
    position: absolute;
    top: -6px;
    right: -6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 4px;
    border-radius: 10px;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    font-size: 11px;
    font-weight: 700;
}

.vc-checkout-summary__item-name {
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-primary);
    font-weight: 500;
}

.vc-checkout-summary__item-info {
    min-width: 0;
}

.vc-checkout-summary__item-info .variation {
    font-size: 12px;
    color: var(--vc-text-secondary);
}

.vc-checkout-summary__item-price {
    font-size: var(--vc-font-size-sm);
    font-weight: 700;
    color: var(--vc-white);
    white-space: nowrap;
}

/* Summary totals rows */
.vc-checkout-summary__totals {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.vc-checkout-summary__row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-primary);
}

.vc-checkout-summary__row--coupon {
    color: var(--vc-success);
}

.vc-checkout-summary__row--total {
    margin-top: 0.5rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--vc-border);
    font-size: var(--vc-font-size-lg);
    font-weight: 700;
    color: var(--vc-white);
}

/* Hide duplicate WC headings (our section headers already show these) */
.vc-checkout-section__body h3,
.vc-checkout-section__body > .woocommerce-billing-fields > h3,
.vc-checkout-section__body > .woocommerce-shipping-fields > h3,
.vc-checkout-section__body .woocommerce-billing-fields h3,
.vc-checkout-section__body .woocommerce-shipping-fields h3 {
    display: none;
}

/* Checkout forms — coupon toggle, login, info */
.woocommerce-checkout .woocommerce-form-coupon-toggle,
.woocommerce-checkout .woocommerce-form-login-toggle {
    margin-bottom: 1.5rem;
}

.woocommerce form.checkout_coupon,
.woocommerce form.login {
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    color: var(--vc-text-primary);
}

.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    background: var(--vc-bg-input);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
    color: var(--vc-text-primary);
    padding: 0.625rem 0.75rem;
    font-size: var(--vc-font-size-base);
    font-family: var(--vc-font-family);
    transition: border-color var(--vc-transition);
    width: 100%;
}

.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
    border-color: var(--vc-accent);
    outline: none;
    box-shadow: 0 0 0 3px rgba(228, 63, 90, 0.1);
}

.woocommerce-checkout .woocommerce-info,
.woocommerce .woocommerce-info {
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-left: 4px solid var(--vc-accent);
    border-radius: var(--vc-radius);
    color: var(--vc-text-primary);
    padding: 1rem 1.25rem 1rem 1.5rem;
    font-size: var(--vc-font-size-sm);
    overflow: visible;
    list-style: none;
}

.woocommerce-checkout .woocommerce-info::before,
.woocommerce .woocommerce-info::before {
    display: none;
}

.woocommerce form .form-row {
    margin-bottom: 1rem;
}

.woocommerce form .form-row label {
    font-weight: 500;
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-primary);
    margin-bottom: 0.375rem;
}

.woocommerce form .form-row .required {
    color: var(--vc-accent);
}

/* Payment section */
.woocommerce #payment {
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
}

.woocommerce #payment ul.payment_methods {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
}

.woocommerce #payment ul.payment_methods li {
    padding: 1rem;
    margin-bottom: 0.5rem;
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
    transition: border-color var(--vc-transition);
}

.woocommerce #payment ul.payment_methods li:hover {
    border-color: var(--vc-accent);
}

.woocommerce #payment ul.payment_methods li label {
    font-weight: 600;
    cursor: pointer;
}

.woocommerce #payment div.payment_box {
    background: var(--vc-bg-section);
    border-radius: var(--vc-radius-sm);
    padding: 1rem;
    margin-top: 0.75rem;
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-secondary);
    position: relative;
}

.woocommerce #payment div.payment_box::before {
    display: none;
}

/* Terms and conditions checkbox — inline with label */
.woocommerce-checkout #payment .place-order .woocommerce-terms-and-conditions-wrapper {
    text-align: left;
    margin-bottom: 1.25rem;
}

.woocommerce-checkout #payment .place-order .woocommerce-terms-and-conditions-wrapper .woocommerce-privacy-policy-text {
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-secondary);
    margin-bottom: 1rem;
}

.woocommerce-checkout #payment .place-order .woocommerce-terms-and-conditions-wrapper .form-row label.checkbox {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.625rem;
    cursor: pointer;
    font-size: var(--vc-font-size-sm);
}

.woocommerce-checkout #payment .place-order .woocommerce-terms-and-conditions-wrapper .form-row label.checkbox input.input-checkbox,
.woocommerce-checkout #payment .place-order .woocommerce-terms-and-conditions-wrapper .form-row label.checkbox input[type="checkbox"] {
    display: inline-block;
    flex-shrink: 0;
    margin: 0.2em 0 0 0;
    width: 18px;
    height: 18px;
    accent-color: var(--vc-accent);
    cursor: pointer;
}

.woocommerce #payment #place_order {
    width: 100%;
    padding: 1rem;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    border: none;
    border-radius: var(--vc-radius);
    font-size: var(--vc-font-size-lg);
    font-weight: 700;
    cursor: pointer;
    transition: background var(--vc-transition);
    font-family: var(--vc-font-family);
}

.woocommerce #payment #place_order:hover {
    background: var(--vc-accent-hover);
}

/* Hide the duplicate order review table on checkout (sidebar handles summary) */
.woocommerce-checkout .woocommerce-checkout-review-order-table {
    display: none;
}

/* Checkout trust signal */
.vc-checkout-trust {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 1rem;
    padding: 0.75rem;
    font-size: var(--vc-font-size-xs);
    color: var(--vc-text-secondary);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
    background: var(--vc-bg-section);
}

.vc-checkout-trust svg {
    flex-shrink: 0;
    color: var(--vc-success);
}

/* My Account */
.woocommerce-account .woocommerce-MyAccount-navigation {
    float: none;
    width: 100%;
    margin-bottom: 1.5rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    overflow: hidden;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    flex: 1;
    min-width: fit-content;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 0.75rem 1.25rem;
    text-align: center;
    font-size: var(--vc-font-size-sm);
    font-weight: 500;
    color: var(--vc-text-secondary);
    border-bottom: 2px solid var(--vc-border);
    transition: all var(--vc-transition);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
    color: var(--vc-white);
    border-bottom-color: var(--vc-accent);
    background: var(--vc-bg-section);
}

.woocommerce-account .woocommerce-MyAccount-content {
    float: none;
    width: 100%;
}

/* Login / Register form */
.woocommerce form.woocommerce-form-login,
.woocommerce form.woocommerce-form-register {
    background: var(--vc-bg-card);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    padding: 2rem;
}

/* Form input fields (dark theme) */
.woocommerce form .form-row input.input-text {
    background: var(--vc-bg-input);
    border-color: var(--vc-border);
    color: var(--vc-text-primary);
}

.woocommerce form .woocommerce-button,
.woocommerce button.button {
    padding: 0.75rem 1.5rem;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    border: none;
    border-radius: var(--vc-radius-sm);
    font-size: var(--vc-font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--vc-transition);
    font-family: var(--vc-font-family);
}

.woocommerce form .woocommerce-button:hover,
.woocommerce button.button:hover {
    background: var(--vc-accent-hover);
}

/* Update cart button */
.woocommerce button[name="update_cart"],
.woocommerce input[name="update_cart"] {
    padding: 0.625rem 1.5rem;
    background: var(--vc-bg-section);
    color: var(--vc-text-primary);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
    font-size: var(--vc-font-size-sm);
    font-weight: 600;
    cursor: pointer;
    font-family: var(--vc-font-family);
    transition: background var(--vc-transition), border-color var(--vc-transition);
}

.woocommerce button[name="update_cart"]:hover,
.woocommerce input[name="update_cart"]:hover {
    background: var(--vc-accent);
    color: var(--vc-always-white);
    border-color: var(--vc-accent);
}

.woocommerce button[name="update_cart"]:disabled,
.woocommerce input[name="update_cart"]:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

/* Cart updating state (while AJAX refresh in progress) */
.vc-cart--updating .vc-cart-items {
    opacity: 0.5;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

/* Coupon */
.woocommerce .coupon {
    display: flex;
    gap: 0.5rem;
    align-items: flex-end;
}

.woocommerce .coupon .input-text {
    max-width: 200px;
}

/* ==========================================================================
   Mini-Cart — Improved Items
   ========================================================================== */

.vc-mini-cart-item {
    display: grid;
    grid-template-columns: 64px 1fr auto;
    gap: 0.75rem;
    align-items: center;
    padding: 0.5rem 0;
}

.vc-mini-cart-item__image {
    position: relative;
    width: 64px;
    height: 64px;
}

.vc-mini-cart-item__image img {
    width: 64px;
    height: 64px;
    object-fit: cover;
    border-radius: var(--vc-radius-sm);
}

.vc-mini-cart-item__qty-badge {
    position: absolute;
    top: -5px;
    right: -5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: 9px;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    font-size: 10px;
    font-weight: 700;
}

.vc-mini-cart-item__info {
    min-width: 0;
}

.vc-mini-cart-item__name {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: var(--vc-font-size-sm);
    font-weight: 500;
    color: var(--vc-text-primary);
    margin-bottom: 0.25rem;
    word-break: break-word;
}

a.vc-mini-cart-item__name:hover {
    color: var(--vc-accent);
}

.vc-mini-cart-item__info .quantity {
    font-size: 12px;
    color: var(--vc-text-secondary);
}

.vc-mini-cart-item__remove {
    flex-shrink: 0;
}

.vc-mini-cart-item__remove .remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--vc-bg-section);
    color: var(--vc-text-secondary);
    font-size: 0.875rem;
    line-height: 1;
    text-decoration: none;
    transition: all var(--vc-transition);
}

.vc-mini-cart-item__remove .remove:hover {
    background: var(--vc-accent);
    color: var(--vc-always-white);
}

/* Mini-cart list item override */
.woocommerce-mini-cart .woocommerce-mini-cart-item {
    padding: 0;
    margin: 0;
    list-style: none;
}

/* Mini-cart empty state */
.vc-mini-cart-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 2rem 1rem;
    text-align: center;
}

.vc-mini-cart-empty__icon {
    color: var(--vc-text-secondary);
    margin-bottom: 1rem;
    opacity: 0.7;
}

.vc-mini-cart-empty__text {
    font-size: var(--vc-font-size-base);
    color: var(--vc-text-secondary);
    margin: 0 0 1rem;
}

.vc-mini-cart-empty__cta {
    display: inline-flex;
    align-items: center;
    padding: 0.625rem 1.5rem;
    background: var(--vc-accent);
    color: var(--vc-always-white);
    border: none;
    border-radius: var(--vc-radius);
    font-size: var(--vc-font-size-sm);
    font-weight: 600;
    text-decoration: none;
    transition: background var(--vc-transition);
    font-family: var(--vc-font-family);
}

.vc-mini-cart-empty__cta:hover {
    background: var(--vc-accent-hover);
    color: var(--vc-always-white);
}

/* Star rating */
.woocommerce .star-rating {
    color: var(--vc-warning);
    font-size: var(--vc-font-size-sm);
    margin: 0.25rem 1rem 0;
}

.woocommerce .star-rating span::before {
    color: var(--vc-warning);
}

/* WooCommerce Notices — color-coded backgrounds */
.woocommerce-message {
    background: rgba(34, 197, 94, 0.06);
    border: 1px solid rgba(34, 197, 94, 0.15);
    border-left: 4px solid var(--vc-success);
    border-radius: var(--vc-radius);
    color: #166534;
    padding: 0.875rem 1.25rem;
    font-size: var(--vc-font-size-sm);
    margin-bottom: 1rem;
}

.woocommerce-error {
    background: rgba(228, 63, 90, 0.06);
    border: 1px solid rgba(228, 63, 90, 0.15);
    border-left: 4px solid var(--vc-accent);
    border-radius: var(--vc-radius);
    color: #9f1239;
    padding: 0.875rem 1.25rem;
    font-size: var(--vc-font-size-sm);
    margin-bottom: 1rem;
}

.woocommerce-info {
    background: rgba(59, 130, 246, 0.06);
    border: 1px solid rgba(59, 130, 246, 0.15);
    border-left: 4px solid #3b82f6;
    border-radius: var(--vc-radius);
    color: var(--vc-text-primary);
    padding: 0.875rem 1.25rem;
    font-size: var(--vc-font-size-sm);
    margin-bottom: 1rem;
}

.woocommerce-message a,
.woocommerce-error a,
.woocommerce-info a {
    font-weight: 600;
    text-decoration: underline;
}

/* Return to shop button (empty cart) */
.woocommerce .return-to-shop .button,
.woocommerce .wc-backward {
    display: inline-flex;
    align-items: center;
    padding: 0.625rem 1.5rem;
    background: var(--vc-bg-card);
    color: var(--vc-text-primary);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius);
    font-size: var(--vc-font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--vc-transition);
    text-decoration: none;
    font-family: var(--vc-font-family);
}

.woocommerce .return-to-shop .button:hover,
.woocommerce .wc-backward:hover {
    background: var(--vc-accent);
    color: var(--vc-always-white);
    border-color: var(--vc-accent);
}

/* Product gallery dark background */
.woocommerce div.product div.images .woocommerce-product-gallery__image,
.woocommerce div.product div.images .flex-viewport {
    background: var(--vc-bg-card);
    border-radius: var(--vc-radius);
}

.woocommerce div.product div.images .flex-control-thumbs li img {
    background: var(--vc-bg-card);
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-border);
}

.woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs li img:hover {
    border-color: var(--vc-accent);
}

/* Breadcrumb — dark theme */
.vc-breadcrumb {
    background: var(--vc-bg-section);
    color: var(--vc-text-secondary);
}

.vc-breadcrumb a {
    color: var(--vc-text-secondary);
}

.vc-breadcrumb a:hover {
    color: var(--vc-white);
}

/* WooCommerce Pagination (list-type output) */
.woocommerce-pagination ul {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    list-style: none;
    padding: 0;
    margin: 2rem 0;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 0.75rem;
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
    font-size: var(--vc-font-size-sm);
    color: var(--vc-text-primary);
    background: var(--vc-bg-card);
    transition: all var(--vc-transition);
}

.woocommerce-pagination ul li a:hover {
    border-color: var(--vc-accent);
    color: var(--vc-accent);
}

.woocommerce-pagination ul li span.current {
    background: var(--vc-accent);
    border-color: var(--vc-accent);
    color: var(--vc-always-white);
}

/* ==========================================================================
   Filter toggle button — mobile only
   ========================================================================== */

.vc-sidebar-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 3px;
    font-family: 'Roboto', sans-serif;
    font-size: 0.8125rem;
    font-weight: 500;
    color: #333;
    cursor: pointer;
    margin-bottom: 1rem;
    transition: border-color 0.2s ease;
}

.vc-sidebar-toggle:hover {
    border-color: #999;
}

.vc-sidebar-toggle:focus-visible {
    outline: 2px solid #333;
    outline-offset: 2px;
}

@media (min-width: 1024px) {
    .vc-sidebar-toggle {
        display: none;
    }
}

/* ==========================================================================
   Focus States — Accessibility
   ========================================================================== */

.vc-qty-btn:focus-visible,
.vc-cart-item__remove .remove:focus-visible,
.vc-mini-cart-item__remove .remove:focus-visible {
    outline: 2px solid var(--vc-accent);
    outline-offset: 2px;
}

.woocommerce .cart_totals .wc-proceed-to-checkout .checkout-button:focus-visible,
.woocommerce #payment #place_order:focus-visible {
    outline: 2px solid var(--vc-always-white);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--vc-accent);
}

.vc-mini-cart-empty__cta:focus-visible,
.woocommerce button.button:focus-visible {
    outline: 2px solid var(--vc-accent);
    outline-offset: 2px;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

/* Sidebar overlay (injected by JS) */
.vc-sidebar-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    z-index: 9999;
}

.vc-sidebar-overlay--open {
    opacity: 1;
    visibility: visible;
}

@media (min-width: 1024px) {
    .vc-sidebar-overlay {
        display: none;
    }
}

/* Sidebar header (injected by JS — mobile only) */
.vc-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0;
    margin-bottom: 1rem;
    border-bottom: 1px solid #eee;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
}

.vc-sidebar-header__title {
    font-size: 1rem;
    font-weight: 600;
    color: #333;
}

@media (min-width: 1024px) {
    .vc-sidebar-header {
        display: none;
    }
}

/* Sidebar close button */
.vc-sidebar-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--vc-text-primary);
    border-radius: var(--vc-radius-sm);
    flex-shrink: 0;
}

.vc-sidebar-close:hover {
    background: var(--vc-bg-card);
}

/* Mobile: larger touch targets for price slider */
@media (max-width: 1023px) {
    .vc-price-slider__input::-webkit-slider-thumb {
        width: 18px;
        height: 18px;
        margin-top: -7px;
    }

    .vc-price-slider__input::-moz-range-thumb {
        width: 18px;
        height: 18px;
    }
}

/* Tablet: Cart + Checkout single-column */
@media (max-width: 991px) {
    .vc-cart-layout {
        grid-template-columns: 1fr;
    }

    .vc-cart-layout__summary {
        position: static;
    }

    .vc-checkout-layout {
        grid-template-columns: 1fr;
    }

    .vc-checkout-layout__sidebar {
        order: -1;
        position: static;
    }
}

/* Tablet: Cart items stack actions below */
@media (max-width: 767px) {
    .vc-cart-item {
        grid-template-columns: 64px 1fr;
        grid-template-areas:
            "image details"
            "actions actions";
        gap: 0.75rem;
        padding: 1rem;
        padding-right: 2.25rem;
    }

    .vc-cart-item__image img {
        width: 64px;
        height: 64px;
    }

    .vc-cart-item__actions {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .vc-cart-actions {
        flex-direction: column;
        gap: 0.625rem;
    }

    .vc-cart-coupon {
        flex-direction: column;
        width: 100%;
    }

    .vc-cart-coupon .input-text {
        max-width: 100%;
        width: 100%;
    }

    .vc-cart-coupon .button {
        width: 100%;
        min-height: 44px;
    }

    .woocommerce .cart_totals {
        max-width: 100%;
    }
}

/* Mobile: products first, tighter spacing */
@media (max-width: 767px) {

    /* Improve product card readability on mobile */
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }

    .woocommerce ul.products li.product .woocommerce-loop-product__title {
        font-size: 0.8125rem;
        padding: 0.625rem 0.625rem 0.25rem;
    }

    .woocommerce ul.products li.product .price {
        padding: 0 0.625rem;
        font-size: var(--vc-font-size-sm);
        white-space: normal;
        word-break: break-word;
    }

    /* Add-to-cart button — prominent on mobile with proper tap target */
    .woocommerce ul.products li.product .button,
    .woocommerce ul.products li.product a.add_to_cart_button,
    .woocommerce ul.products li.product a.product_type_variable,
    .woocommerce ul.products li.product a.product_type_simple {
        margin: auto 0.625rem 0.625rem;
        padding: 0.625rem 0.75rem;
        font-size: var(--vc-font-size-sm);
        min-height: 44px;
    }

    .vc-product-card__meta {
        padding: 0.25rem 0.625rem 0;
    }

    .vc-product-card__var-list {
        max-height: 3rem;
    }

    .vc-product-card__var-item {
        font-size: 9px;
        padding: 0.0625rem 0.375rem;
    }

    /* Shop toolbar — stack vertically to prevent overlap */
    .woocommerce-notices-wrapper + .woocommerce-result-count,
    .woocommerce-result-count {
        float: none;
        text-align: center;
        line-height: 1.5;
        margin-bottom: 0.5rem;
    }

    .woocommerce-ordering {
        float: none;
        width: 100%;
    }

    .woocommerce-ordering select {
        width: 100%;
        min-width: 0;
    }

    /* Touch targets — 44px minimum for mobile */
    .vc-qty-btn {
        width: 44px;
        height: 44px;
    }

    .vc-qty-wrapper .qty {
        height: 44px;
        width: 48px;
    }

    .vc-cart-item__remove .remove {
        width: 36px;
        height: 36px;
        font-size: 1.125rem;
        opacity: 1;
    }

    /* Variation select — prevent overflow on single product */
    .woocommerce div.product form.cart .variations select {
        min-width: 0;
        width: 100%;
    }

    .woocommerce div.product form.cart .variations {
        display: block;
    }

    .woocommerce div.product form.cart .variations tr {
        display: flex;
        flex-direction: column;
        margin-bottom: 0.75rem;
    }

    .woocommerce div.product form.cart .variations td,
    .woocommerce div.product form.cart .variations th {
        display: block;
        width: 100%;
        padding: 0.25rem 0;
    }

    /* Single product add-to-cart — prominent */
    .woocommerce div.product form.cart .single_add_to_cart_button {
        width: 100%;
        min-height: 48px;
        font-size: var(--vc-font-size-lg);
    }

    .woocommerce div.product form.cart {
        gap: 0.5rem;
    }

    .woocommerce div.product form.cart .quantity {
        width: 100%;
    }

    .woocommerce .quantity .qty {
        width: 100%;
    }

    /* Product tabs — horizontal scroll */
    .woocommerce div.product .woocommerce-tabs ul.tabs {
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs::-webkit-scrollbar {
        display: none;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs li a {
        padding: 0.625rem 1rem;
        font-size: var(--vc-font-size-xs);
    }

    .woocommerce div.product .woocommerce-tabs .panel {
        padding: 1rem;
    }

    /* My Account navigation — horizontal scroll */
    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul::-webkit-scrollbar {
        display: none;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul li {
        flex: 0 0 auto;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul li a {
        padding: 0.625rem 1rem;
        font-size: var(--vc-font-size-xs);
        min-height: 44px;
        display: flex;
        align-items: center;
    }

    /* Checkout — tighter on mobile */
    .vc-checkout-section .form-row {
        margin-bottom: 1rem;
    }

    .vc-checkout-section__body {
        padding: 1rem;
    }

    /* Sidebar category toggle — larger tap target */
    .vc-shop-layout__sidebar .widget_product_categories .product-categories li.cat-parent .vc-cat-toggle {
        width: 44px;
        height: 44px;
        font-size: 18px;
    }

    /* Sidebar links — larger touch targets */
    .vc-shop-layout__sidebar .widget ul li a {
        padding: 0.5rem 0;
        min-height: 44px;
        display: flex;
        align-items: center;
    }

    /* Star rating on cards */
    .woocommerce .star-rating {
        margin: 0.25rem 0.625rem 0;
    }
}

/* ==========================================================================
   WC Form Row Layout (replaces woocommerce-layout.css form rules)
   ========================================================================== */

.woocommerce form .form-row {
    padding: 3px;
    margin: 0 0 6px;
}

.woocommerce form .form-row label {
    display: block;
}

.woocommerce form .form-row select,
.woocommerce form .form-row .input-text {
    box-sizing: border-box;
    width: 100%;
}

.woocommerce form .form-row-first,
.woocommerce form .form-row-last {
    width: 47%;
    overflow: visible;
}

.woocommerce form .form-row-first {
    float: left;
}

.woocommerce form .form-row-last {
    float: right;
}

.woocommerce form .form-row-wide {
    clear: both;
}

.woocommerce .col2-set {
    width: 100%;
}

.woocommerce .col2-set::after {
    content: "";
    display: table;
    clear: both;
}

.woocommerce .col2-set .col-1 {
    float: left;
    width: 48%;
}

.woocommerce .col2-set .col-2 {
    float: right;
    width: 48%;
}

/* Cart collaterals */
.woocommerce .cart-collaterals {
    width: 100%;
}

.woocommerce .cart-collaterals::after {
    content: "";
    display: table;
    clear: both;
}

.woocommerce .cart-collaterals .cart_totals {
    float: none;
    width: 100%;
}

/* Mobile: stack form rows */
@media (max-width: 767px) {
    .woocommerce form .form-row-first,
    .woocommerce form .form-row-last {
        float: none;
        width: 100%;
    }

    .woocommerce .col2-set .col-1,
    .woocommerce .col2-set .col-2 {
        float: none;
        width: 100%;
    }

    .woocommerce .cart-collaterals .cart_totals {
        float: none;
        width: 100%;
    }
}

@media (min-width: 768px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem;
    }

    .woocommerce div.product div.images,
    .woocommerce div.product div.summary {
        float: left;
        width: 48%;
    }

    .woocommerce div.product div.summary {
        float: right;
    }

    /* Checkout uses CSS grid layout — no floats needed */
}

@media (min-width: 1024px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(3, 1fr);
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        float: left;
        width: 25%;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        flex-direction: column;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul li a {
        text-align: left;
        border-bottom: none;
        border-left: 2px solid transparent;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
    .woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
        border-bottom: none;
        border-left-color: var(--vc-accent);
        background: var(--vc-bg-section);
    }

    .woocommerce-account .woocommerce-MyAccount-content {
        float: right;
        width: 72%;
    }
}

@media (min-width: 1200px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(4, 1fr);
    }
}
