/* ============================================================
   EFISHOP — WooCommerce Overrides
   Applies design tokens to all WC native elements
   ============================================================ */

/* ── WC Global ──────────────────────────────────────────── */

.woocommerce,
.woocommerce-page {
    color: var(--on-surface);
}

/* Remove WC default focus outline (we handle it) */
.woocommerce a:focus,
.woocommerce button:focus {
    outline: none;
}

/* ── Messages / Notices ─────────────────────────────────── */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notice {
    border: none !important;
    border-radius: var(--radius-lg) !important;
    padding: var(--space-4) var(--space-6) !important;
    margin-bottom: var(--space-6) !important;
    display: flex !important;
    align-items: center !important;
    gap: var(--space-4) !important;
    font-size: var(--text-body-sm) !important;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before,
.woocommerce-notice::before {
    position: static !important;
    margin: 0 !important;
    display: inline-block !important;
}

.woocommerce-message {
    background-color: #d1fae5 !important;
    color: #065f46 !important;
}

.woocommerce-info {
    background-color: var(--secondary-container) !important;
    color: var(--on-secondary-container) !important;
}

.woocommerce-error {
    background-color: var(--error-container) !important;
    color: var(--on-error-container) !important;
}

/* ── Buttons (override WC defaults) ─────────────────────── */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .wc-block-components-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-3) var(--space-8);
    background-color: var(--surface-container-high) !important;
    color: var(--on-surface) !important;
    border: none !important;
    border-radius: var(--radius-full) !important;
    font-family: var(--font-label) !important;
    font-size: var(--text-label-lg) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast) !important;
    box-shadow: none !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
    background-color: var(--surface-container-highest) !important;
    transform: translateY(-1px);
}

/* Alt / primary WC button */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
    background: linear-gradient(145deg, var(--secondary), var(--secondary-dim)) !important;
    color: var(--on-secondary) !important;
    box-shadow: var(--shadow-ambient-sm) !important;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background: linear-gradient(145deg, var(--secondary-dim), #004090) !important;
    box-shadow: var(--shadow-ambient) !important;
    transform: translateY(-1px);
}

/* Single product Add to Cart */
.woocommerce .single_add_to_cart_button {
    background: linear-gradient(145deg, var(--secondary), var(--secondary-dim)) !important;
    color: var(--on-secondary) !important;
    box-shadow: var(--shadow-ambient-sm) !important;
    width: 100%;
    padding: var(--space-4) var(--space-10) !important;
    font-size: var(--text-title-md) !important;
}

/* ── Forms ──────────────────────────────────────────────── */

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce-page form .form-row input.input-text {
    background-color: var(--surface-container-high) !important;
    border: 2px solid transparent !important;
    border-radius: var(--radius-full) !important;
    color: var(--on-surface) !important;
    padding: var(--space-3) var(--space-6) !important;
    font-family: var(--font-body) !important;
    font-size: var(--text-body-md) !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
    box-shadow: none !important;
}

.woocommerce form .form-row textarea {
    background-color: var(--surface-container-high) !important;
    border: 2px solid transparent !important;
    border-radius: var(--radius-lg) !important;
    color: var(--on-surface) !important;
    padding: var(--space-4) var(--space-6) !important;
    font-family: var(--font-body) !important;
    font-size: var(--text-body-md) !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
    box-shadow: none !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    border-color: rgba(0, 91, 194, 0.40) !important;
    background-color: var(--surface-container-lowest) !important;
    box-shadow: 0 0 0 4px rgba(0, 91, 194, 0.08) !important;
    outline: none !important;
}

/* ── Single Product Title & Price ──────────────────────── */
.efishop-product-title {
    font-family: var(--font-headline) !important;
    font-size: var(--text-display-sm) !important;
    font-weight: 800 !important;
    color: var(--on-surface) !important;
    line-height: 1.1 !important;
    margin-bottom: var(--space-4) !important;
}

.efishop-product-price .price,
.efishop-product-price .woocommerce-Price-amount {
    font-family: var(--font-headline) !important;
    font-size: var(--text-headline-md) !important;
    font-weight: 800 !important;
    color: var(--secondary) !important;
    display: block !important;
    margin: var(--space-6) 0 !important;
}

/* ── Spec Cards (Premium) ─────────────────────────────── */
.efishop-spec-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
    margin: var(--space-8) 0;
}

.spec-card {
    background: var(--surface-container-low);
    padding: var(--space-6);
    border-radius: var(--radius-xl);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    transition: all 0.3s ease;
    border: 1px solid var(--outline-variant);
}

.spec-card:hover {
    background: var(--surface-container-lowest);
    transform: translateY(-4px);
    box-shadow: var(--shadow-elevated);
    border-color: var(--secondary);
}

.spec-card__label {
    font-size: var(--text-label-sm);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--on-surface-variant);
    letter-spacing: 0.05em;
}

.spec-card__value {
    font-size: var(--text-title-md);
    font-weight: 800;
    color: var(--on-surface);
}

/* ── Add to Cart & Trust Badges ────────────────────────── */
.efishop-product-atc {
    margin-top: var(--space-8);
}

.product-trust-badges {
    display: flex;
    gap: var(--space-6);
    margin-top: var(--space-8);
    padding-top: var(--space-6);
    border-top: 1px solid var(--outline-variant);
}

.product-trust-badges span {
    font-size: var(--text-label-lg);
    font-weight: 600;
    color: var(--on-surface-variant);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.woocommerce form .form-row label {
    font-size: var(--text-label-lg) !important;
    font-weight: 500 !important;
    color: var(--on-surface-variant) !important;
    margin-bottom: var(--space-2) !important;
}

/* ── Product Archive (Shop) ─────────────────────────────── */

.woocommerce ul.products,
.woocommerce-page ul.products {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
    gap: var(--space-8) !important;
    margin: var(--space-8) 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
    display: none !important;
}

/* Hard kill for WC column widths */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.woocommerce ul.products[class*="columns-"] li.product,
.woocommerce-page ul.products[class*="columns-"] li.product {
    width: 100% !important;
    float: none !important;
    clear: none !important;
    margin: 0 !important;
    padding: var(--space-6) !important;
}

@media (min-width: 1200px) {
    .woocommerce ul.products,
    .woocommerce-page ul.products {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (min-width: 1024px) {
    .woocommerce ul.products,
    ul.products.columns-3,
    ul.products.columns-4 {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

.woocommerce ul.products li.product {
    background-color: var(--surface-container-lowest) !important;
    border-radius: var(--radius-3xl) !important;
    padding: var(--space-6) !important;
    margin: 0 !important;
    transition: all 0.3s ease !important;
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
    height: auto !important; /* Let content dictate height */
    width: 100% !important;
    float: none !important;
    position: relative !important;
    box-shadow: var(--shadow-ambient) !important;
    overflow: hidden !important;
}

.woocommerce ul.products li.product .efishop-card__inner {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-4) !important;
    height: 100% !important;
    width: 100% !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__link {
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;
    text-decoration: none !important;
}

.woocommerce ul.products li.product .efishop-card__content {
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;
    padding: 0 !important;
    text-align: left !important;
}

.woocommerce ul.products li.product:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-elevated);
}

.woocommerce ul.products li.product .woocommerce-loop-product__link {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
}

.woocommerce ul.products li.product .woocommerce-loop-product__link img,
.woocommerce ul.products li.product img {
    border-radius: var(--radius-2xl) !important;
    background-color: var(--surface-container-low) !important;
    object-fit: contain !important;
    width: 100% !important;
    height: 300px !important; /* Fixed height for consistency */
    padding: var(--space-8) !important;
    margin-bottom: 0 !important;
    display: block !important;
    border: none !important;
    transition: transform 0.5s ease;
}

.woocommerce ul.products li.product:hover img {
    transform: scale(1.05);
}

.woocommerce ul.products li.product:hover img {
    transform: scale(1.02);
}

.efishop-card__category {
    font-size: var(--text-label-sm);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--secondary);
    letter-spacing: var(--tracking-wider);
    margin-bottom: var(--space-1);
    display: block;
}

.efishop-card__title,
.efishop-card__title a {
    font-family: var(--font-headline) !important;
    font-size: var(--text-title-md) !important;
    font-weight: 800 !important;
    color: var(--on-surface) !important;
    line-height: 1.2 !important;
    margin: var(--space-1) 0 !important;
    padding: 0 !important;
    text-decoration: none !important;
    display: block !important;
}

.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product .efishop-card__price {
    font-family: var(--font-headline) !important;
    font-size: var(--text-headline-sm) !important;
    font-weight: 800 !important;
    color: var(--secondary) !important;
    display: block !important;
    margin: var(--space-1) 0 var(--space-4) !important;
    padding: 0 !important;
    margin-top: auto !important;
}

/* Add to cart button in loop */
.woocommerce ul.products li.product .button {
    background-color: var(--secondary) !important;
    color: var(--on-secondary) !important;
    border-radius: var(--radius-full) !important;
    padding: var(--space-3) var(--space-6) !important;
    font-size: var(--text-label-md) !important;
    font-weight: 700 !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
    margin: 0 !important;
}

.woocommerce ul.products li.product .button:hover {
    background-color: var(--secondary-dim) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(0, 91, 194, 0.2) !important;
}

.efishop-card__title {
    font-family: var(--font-headline) !important;
    font-size: var(--text-title-lg) !important;
    font-weight: 800 !important;
    color: var(--on-surface) !important;
    margin-bottom: var(--space-2) !important;
    line-height: 1.2 !important;
    display: block !important;
}

.woocommerce ul.products li.product .price del,
.efishop-card__price del {
    color: var(--outline) !important;
    font-size: var(--text-body-sm) !important;
    font-weight: 400;
    opacity: 0.7 !important;
}

.woocommerce ul.products li.product .price ins,
.efishop-card__price ins {
    text-decoration: none !important;
}

.woocommerce ul.products li.product .button {
    margin-top: auto !important;
    width: 100% !important;
    background: linear-gradient(145deg, var(--secondary), var(--secondary-dim)) !important;
    color: var(--on-secondary) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    border-radius: var(--radius-full) !important;
    padding: var(--space-3) var(--space-4) !important;
    font-size: var(--text-label-md) !important;
    font-weight: 700 !important;
    text-align: center !important;
    min-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: none !important;
    transition: all 0.3s ease !important;
}

.woocommerce ul.products li.product .button:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--shadow-ambient) !important;
}

/* Onsale badge */
.woocommerce span.onsale {
    background-color: var(--error) !important;
    color: var(--on-error) !important;
    border-radius: var(--radius-full) !important;
    font-size: var(--text-label-sm) !important;
    font-weight: 700 !important;
    padding: var(--space-1) var(--space-3) !important;
    min-width: auto !important;
    min-height: auto !important;
    line-height: 1.4 !important;
}

/* ── Single Product ──────────────────────────────────────── */

.woocommerce div.product {
    display: block;
}

.woocommerce div.product .woocommerce-product-gallery {
    background-color: var(--surface-container-lowest);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-ambient);
}

.woocommerce div.product .woocommerce-product-gallery img {
    border-radius: var(--radius-lg);
}

.woocommerce div.product .summary {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.woocommerce div.product .product_title {
    font-family: var(--font-headline) !important;
    font-size: var(--text-display-sm) !important;
    font-weight: 800 !important;
    color: var(--on-surface) !important;
    line-height: var(--leading-tight) !important;
    letter-spacing: var(--tracking-tight) !important;
}

.woocommerce div.product .price {
    font-family: var(--font-headline);
    font-size: var(--text-display-sm) !important;
    font-weight: 800;
    color: var(--on-surface) !important;
}

.woocommerce div.product .price del {
    font-size: var(--text-headline-sm) !important;
    color: var(--outline) !important;
    opacity: 1 !important;
    font-weight: 400;
}

.woocommerce div.product .woocommerce-product-rating {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.woocommerce div.product .stock {
    font-size: var(--text-label-md);
    font-weight: 600;
    color: #059669;
    background-color: #d1fae5;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    display: inline-block;
}

.woocommerce div.product .out-of-stock {
    color: var(--error);
    background-color: var(--error-container);
}

/* ── Single Product Layout ──────────────────────────────── */
.efishop-product-layout {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: var(--space-12);
    margin: var(--space-12) 0;
}

@media (min-width: 768px) {
    .product-gallery-wrap {
        position: sticky;
        top: var(--space-8);
    }
}

/* ── Product Gallery (Single) ───────────────────────────── */
.woocommerce div.product div.images {
    width: 100% !important;
    float: none !important;
    margin-bottom: var(--space-8) !important;
}

/* Hide Magnifier and Zoom Triggers (Aggressive) */
.woocommerce-product-gallery__trigger,
.woocommerce-product-gallery__trigger img,
.pswp__button--zoom,
.zoomImg,
.zoomContainer,
.woocommerce-product-gallery__trigger::before,
.woocommerce-product-gallery__trigger::after {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
}

.woocommerce div.product div.images .flex-viewport {
    border-radius: var(--radius-2xl) !important;
    background: var(--surface-container-lowest) !important;
    box-shadow: var(--shadow-ambient) !important;
    overflow: hidden !important;
    margin-bottom: var(--space-4) !important;
}

/* Product Gallery Carousel (Slider) */
.woocommerce div.product div.images .slides {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.woocommerce div.product div.images .slides li {
    flex: 0 0 100% !important;
    width: 100% !important;
    margin: 0 !important;
    list-style: none !important;
}

.woocommerce div.product div.images .flex-control-nav {
    display: flex !important;
    justify-content: center !important;
    gap: var(--space-3) !important;
    margin-top: var(--space-4) !important;
    padding: 0 !important;
    list-style: none !important;
}

.woocommerce div.product div.images .flex-control-nav li {
    margin: 0 !important;
}

.woocommerce div.product div.images .flex-control-nav li img {
    width: 60px !important;
    height: 60px !important;
    object-fit: cover !important;
    border-radius: var(--radius-lg) !important;
    cursor: pointer !important;
    opacity: 0.5 !important;
    transition: opacity 0.3s ease !important;
    border: 2px solid transparent !important;
}

.woocommerce div.product div.images .flex-control-nav li img.flex-active {
    opacity: 1 !important;
    border-color: var(--secondary) !important;
}

.woocommerce div.product div.images .flex-control-thumbs {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--space-3) !important;
    margin-top: var(--space-4) !important;
    padding: 0 !important;
    list-style: none !important;
}

.woocommerce div.product div.images .flex-control-thumbs li {
    width: 80px !important;
    height: 80px !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.woocommerce div.product div.images .flex-control-thumbs img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: var(--radius-lg) !important;
    opacity: 0.5 !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    border: 2px solid transparent !important;
}

.woocommerce div.product div.images .flex-control-thumbs img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs img:hover {
    opacity: 1 !important;
    border-color: var(--secondary) !important;
}

.efishop-product-gallery {
    position: sticky;
    top: calc(var(--space-24) + 20px);
}

.woocommerce-product-gallery {
    opacity: 1 !important;
    margin-bottom: 0 !important;
}

.woocommerce-product-gallery__wrapper {
    margin: 0 !important;
}

.woocommerce-product-gallery img {
    border-radius: var(--radius-2xl) !important;
    background-color: var(--surface-container-low);
    display: block !important;
    width: 100% !important;
    height: auto !important;
    box-shadow: var(--shadow-ambient);
}

/* Floating info card on gallery */
.efishop-product-gallery {
    position: relative;
}

.efishop-product-gallery::after {
    content: "DISEÑO ARTESANAL \A Estructura de aluminio mecanizado con almohadillas de cuero sintético y espuma con memoria para un confort extremo.";
    position: absolute;
    bottom: var(--space-6);
    right: var(--space-6);
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(20px);
    padding: var(--space-4) var(--space-6);
    border-radius: var(--radius-xl);
    font-size: 11px;
    line-height: 1.5;
    color: var(--on-surface-variant);
    max-width: 180px;
    white-space: pre-wrap;
    box-shadow: var(--shadow-ambient-sm);
    z-index: 10;
    display: none; /* Only show if we have this specific info or on specific products */
}

@media (min-width: 991px) {
    .efishop-product-gallery::after {
        display: block;
    }
}

.product-summary-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.product-summary__category {
    font-size: var(--text-label-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color: var(--secondary);
    margin-bottom: calc(-1 * var(--space-2));
}

.efishop-product-title {
    font-family: var(--font-display) !important;
    font-size: clamp(2rem, 5vw, var(--text-display-sm)) !important;
    font-weight: 800 !important;
    color: var(--on-surface) !important;
    line-height: var(--leading-tight) !important;
    letter-spacing: var(--tracking-tight) !important;
    margin: 0 !important;
}

.efishop-product-price {
    margin: var(--space-8) 0;
    padding: var(--space-6) 0;
    border-top: var(--ghost-border);
    border-bottom: var(--ghost-border);
}

.efishop-product-price .woocommerce-Price-amount {
    font-family: var(--font-headline);
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--on-surface);
    letter-spacing: -0.02em;
}

.efishop-product-price del {
    opacity: 0.4;
    font-size: 0.6em;
    margin-right: var(--space-2);
}

.efishop-product-price ins {
    text-decoration: none;
}

.efishop-product-desc {
    font-size: var(--text-body-lg);
    color: var(--on-surface-variant);
    line-height: var(--leading-relaxed);
}

.efishop-product-meta {
    font-size: var(--text-label-md);
    color: var(--on-surface-variant);
    padding-top: var(--space-6);
    border-top: var(--ghost-border);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.efishop-product-atc {
    background-color: var(--surface-container-low);
    padding: var(--space-8);
    border-radius: var(--radius-2xl);
    margin: var(--space-6) 0;
}

/* Spec Cards Enhanced */
.efishop-spec-cards {
    display: flex;
    gap: var(--space-4);
    margin: var(--space-8) 0;
}

.spec-card {
    flex: 1;
    background: var(--surface-container-lowest);
    padding: var(--space-4) var(--space-6);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(var(--on-surface-rgb), 0.05);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    transition: transform 0.3s ease;
}

.spec-card:hover {
    transform: translateY(-4px);
    background: var(--secondary-container);
    color: var(--on-secondary-container);
}

.spec-card__label {
    font-size: var(--text-label-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.6;
}

.spec-card__value {
    font-family: var(--font-headline);
    font-size: var(--text-title-md);
    font-weight: 800;
}

.product-badges {
    display: flex;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
}

.badge {
    background-color: var(--secondary-container);
    color: var(--secondary);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.badge--rating {
    background: none;
    color: var(--on-surface-variant);
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.product-trust-badges {
    display: flex;
    gap: var(--space-6);
    margin-top: var(--space-4);
    font-size: var(--text-label-sm);
    font-weight: 600;
    color: var(--on-surface-variant);
}

.product-trust-badges span {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.woocommerce div.product form.cart {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
    margin-bottom: 0 !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button {
    background: var(--secondary) !important;
    color: var(--on-secondary) !important;
    border-radius: var(--radius-full) !important;
    padding: var(--space-4) var(--space-10) !important;
    font-family: var(--font-display) !important;
    font-size: var(--text-title-md) !important;
    font-weight: 700 !important;
    flex: 1;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--space-3) !important;
    box-shadow: var(--shadow-ambient-sm) !important;
    transition: all var(--transition-fast) !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button::before {
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'%3E%3C/circle%3E%3Ccircle cx='20' cy='21' r='1'%3E%3C/circle%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/path%3E%3C/svg%3E");
    display: inline-block;
    vertical-align: middle;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover {
    background-color: var(--secondary-dim) !important;
    transform: translateY(-2px);
    box-shadow: var(--shadow-ambient) !important;
}

.woocommerce div.product form.cart .qty {
    width: 70px !important;
    height: 54px !important;
    border-radius: var(--radius-full) !important;
    background-color: var(--surface-container-high) !important;
    border: none !important;
    font-family: var(--font-display) !important;
    font-weight: 700 !important;
    font-size: var(--text-body-lg) !important;
}

.woocommerce div.product .woocommerce-tabs {
    margin-top: var(--space-12);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: var(--space-2);
    border-bottom: none !important;
    padding: 0 !important;
    margin-bottom: var(--space-6) !important;
    background: none !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    border: none !important;
    border-radius: var(--radius-full) !important;
    background: var(--surface-container) !important;
    padding: 0 !important;
    margin: 0 !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
    display: none !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    color: var(--on-surface-variant) !important;
    font-size: var(--text-label-md) !important;
    font-weight: 500 !important;
    padding: var(--space-2) var(--space-5) !important;
    display: block;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
    background-color: var(--secondary) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--on-secondary) !important;
    font-weight: 600 !important;
}

.woocommerce div.product .woocommerce-tabs .panel {
    background-color: var(--surface-container-lowest);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    box-shadow: var(--shadow-ambient);
    border: none !important;
    margin: 0 !important;
}

/* Related products */
.woocommerce .related h2,
.woocommerce .upsells h2 {
    font-family: var(--font-headline);
    font-size: var(--text-headline-lg);
    font-weight: 800;
    color: var(--on-surface);
    letter-spacing: var(--tracking-tight);
    margin-bottom: var(--space-8);
}

/* ── Cart ───────────────────────────────────────────────── */

.woocommerce table.shop_table {
    border: none !important;
    border-collapse: separate !important;
    border-spacing: 0 var(--space-3) !important;
    width: 100%;
}

.woocommerce table.shop_table th {
    font-size: var(--text-label-sm) !important;
    font-weight: 700 !important;
    letter-spacing: var(--tracking-wider) !important;
    text-transform: uppercase !important;
    color: var(--on-surface-variant) !important;
    border: none !important;
    padding: var(--space-2) var(--space-4) !important;
    background: none !important;
}

.woocommerce table.shop_table td {
    border: none !important;
    padding: var(--space-4) !important;
    background-color: var(--surface-container-lowest);
    vertical-align: middle !important;
}

.woocommerce table.shop_table tr:first-child td:first-child { border-top-left-radius: var(--radius-lg); }
.woocommerce table.shop_table tr:first-child td:last-child { border-top-right-radius: var(--radius-lg); }
.woocommerce table.shop_table tr:last-child td:first-child { border-bottom-left-radius: var(--radius-lg); }
.woocommerce table.shop_table tr:last-child td:last-child { border-bottom-right-radius: var(--radius-lg); }

.woocommerce table.cart .product-thumbnail img {
    width: 80px;
    height: 80px;
    object-fit: contain;
    border-radius: var(--radius-md);
    background-color: var(--surface-container-low);
    padding: var(--space-2);
}

.woocommerce .cart-collaterals .cart_totals {
    background-color: var(--surface-container-lowest);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    box-shadow: var(--shadow-ambient);
}

.woocommerce .cart-collaterals .cart_totals h2 {
    font-family: var(--font-headline);
    font-size: var(--text-headline-md);
    font-weight: 800;
    margin-bottom: var(--space-6);
}

.woocommerce .cart-collaterals .cart_totals table {
    border: none !important;
    width: 100% !important;
    border-collapse: collapse !important;
}

.woocommerce .cart-collaterals .cart_totals table tbody,
.woocommerce .cart-collaterals .cart_totals table tr {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
}

.woocommerce .cart-collaterals .cart_totals table tr {
    padding: var(--space-4) 0 !important;
    border-bottom: var(--ghost-border) !important;
}

.woocommerce .cart-collaterals .cart_totals table tr:last-child {
    border-bottom: none !important;
}

.woocommerce .cart-collaterals .cart_totals table th,
.woocommerce .cart-collaterals .cart_totals table td {
    display: block !important;
    width: 100% !important;
    padding: 0 !important;
    border: none !important;
    text-align: left !important;
}

.woocommerce .cart-collaterals .cart_totals table th {
    font-size: var(--text-label-sm) !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: var(--on-surface-variant) !important;
    margin-bottom: var(--space-2) !important;
    letter-spacing: var(--tracking-wider) !important;
}

.woocommerce .cart-collaterals .cart_totals table td {
    font-size: var(--text-body-md) !important;
    color: var(--on-surface) !important;
}

.woocommerce .cart-collaterals .cart_totals table tr:last-child th {
    font-size: var(--text-label-sm) !important;
    font-weight: 800 !important;
    color: var(--on-surface) !important;
    margin-bottom: var(--space-1) !important;
}

.woocommerce .cart-collaterals .cart_totals table tr:last-child td {
    font-size: var(--text-headline-sm) !important;
    font-weight: 800 !important;
    color: var(--secondary) !important;
}

.woocommerce .wc-proceed-to-checkout a.checkout-button {
    background: linear-gradient(145deg, var(--secondary), var(--secondary-dim)) !important;
    color: var(--on-secondary) !important;
    width: 100% !important;
    text-align: center !important;
    font-size: var(--text-title-md) !important;
    padding: var(--space-4) var(--space-8) !important;
    margin-top: var(--space-4) !important;
}

/* ── My Account ──────────────────────────────────────────── */

.woocommerce-account .woocommerce-MyAccount-navigation {
    background-color: var(--surface-container-lowest);
    border-radius: var(--radius-xl);
    padding: var(--space-4);
    box-shadow: var(--shadow-ambient);
    width: 100% !important;
    float: none !important;
}

/* ── Pagination Modernization ────────────────────────────── */
.woocommerce-pagination {
    margin: var(--space-24) 0 !important;
    padding-top: var(--space-24) !important;
    display: flex !important;
    justify-content: center !important;
    clear: both !important;
    width: 100% !important;
    border-top: var(--ghost-border) !important;
}

.woocommerce-pagination ul {
    border: none !important;
    display: inline-flex !important;
    gap: var(--space-3) !important;
    background-color: var(--surface-container-lowest);
    padding: var(--space-2) var(--space-4) !important;
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-ambient-sm);
}

.woocommerce-pagination ul li {
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    display: block !important;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 48px !important;
    height: 48px !important;
    padding: 0 var(--space-4) !important;
    background: transparent !important;
    color: var(--on-surface-variant) !important;
    border-radius: var(--radius-full) !important;
    font-weight: 700 !important;
    font-size: var(--text-label-md) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    border: none !important;
    text-decoration: none !important;
}

.woocommerce-pagination ul li span.current {
    background: var(--secondary) !important;
    color: var(--on-secondary) !important;
    box-shadow: 0 4px 12px rgba(0, 91, 194, 0.2);
}

.woocommerce-pagination ul li a:hover {
    background: var(--surface-container-low) !important;
    color: var(--secondary) !important;
    transform: translateY(-2px) !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation li a {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-lg);
    font-size: var(--text-body-sm);
    font-weight: 500;
    color: var(--on-surface-variant);
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
    background-color: var(--secondary-container);
    color: var(--on-secondary-container);
    font-weight: 600;
}

.woocommerce-account .woocommerce-MyAccount-content {
    background-color: var(--surface-container-lowest);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    box-shadow: var(--shadow-ambient);
    width: 100% !important;
    float: none !important;
}

/* ── Checkout ────────────────────────────────────────────── */

.woocommerce-checkout #order_review {
    background-color: var(--surface-container-lowest);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    box-shadow: var(--shadow-ambient);
}

.woocommerce #payment {
    background-color: var(--surface-container-low) !important;
    border-radius: var(--radius-xl) !important;
    border: none !important;
}

.woocommerce #payment ul.payment_methods {
    border-bottom: var(--ghost-border) !important;
    padding: var(--space-6) !important;
}

.woocommerce #payment div.payment_box {
    background-color: var(--surface-container) !important;
    border-radius: var(--radius-lg) !important;
    color: var(--on-surface-variant) !important;
}

.woocommerce #payment div.payment_box::before {
    display: none !important;
}

/* Star ratings */
.woocommerce .star-rating {
    font-family: var(--font-body) !important;
    font-size: 14px !important;
    letter-spacing: 2px !important;
    color: var(--surface-container-highest) !important;
}
.woocommerce .star-rating::before {
    content: "★★★★★" !important;
    color: var(--outline-variant) !important;
    opacity: 0.4 !important;
}
.woocommerce .star-rating span::before {
    content: "★★★★★" !important;
    color: #f59e0b !important;
}

.woocommerce-cart .woocommerce-info {
    margin-bottom: var(--space-8) !important;
}

.woocommerce-cart .return-to-shop {
    text-align: center !important;
    margin-top: var(--space-8) !important;
}

.woocommerce-cart .return-to-shop a.button.wc-backward {
    background: linear-gradient(145deg, var(--secondary), var(--secondary-dim)) !important;
    color: var(--on-secondary) !important;
    padding: var(--space-4) var(--space-10) !important;
    font-size: var(--text-title-md) !important;
    border-radius: var(--radius-full) !important;
    box-shadow: var(--shadow-ambient-sm) !important;
    transition: all var(--transition-fast) !important;
    display: inline-flex !important;
}

.woocommerce-cart .return-to-shop a.button.wc-backward:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--shadow-ambient) !important;
    background: linear-gradient(145deg, var(--secondary-dim), #004090) !important;
}

/* ── Placeholder image (no product image set) ───────────── */

.woocommerce ul.products li.product img.woocommerce-placeholder {
    opacity: 0.18 !important;
    filter: grayscale(1) !important;
    object-fit: contain !important;
    padding: var(--space-12) !important;
}

/* ── Responsive ──────────────────────────────────────────── */

@media (max-width: 767px) {
    .efishop-product-layout {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    .product-gallery-wrap {
        padding: var(--space-4) !important;
        border-radius: var(--radius-lg) !important;
    }

    .woocommerce div.product div.images .flex-control-thumbs {
        position: relative !important;
        flex-direction: row !important;
        width: 100% !important;
        overflow-x: auto;
        padding-bottom: var(--space-4) !important;
    }

    .woocommerce div.product div.images .flex-viewport {
        margin-left: 0 !important;
    }

    .efishop-product-price .woocommerce-Price-amount {
        font-size: 2rem;
    }

    .efishop-spec-cards {
        flex-direction: column;
    }

    /* Modern two-column mobile product loop layout */
    .woocommerce ul.products,
    .woocommerce-page ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: var(--space-3) !important;
        margin: var(--space-4) 0 !important;
    }

    .woocommerce ul.products li.product,
    .woocommerce-page ul.products li.product,
    .woocommerce ul.products[class*="columns-"] li.product,
    .woocommerce-page ul.products[class*="columns-"] li.product {
        padding: var(--space-3) !important;
        border-radius: var(--radius-xl) !important;
    }

    .woocommerce ul.products li.product .woocommerce-loop-product__link img,
    .woocommerce-page ul.products li.product .woocommerce-loop-product__link img,
    .woocommerce ul.products li.product img,
    .woocommerce-page ul.products li.product img {
        height: 140px !important;
        padding: var(--space-3) !important;
        border-radius: var(--radius-lg) !important;
    }

    /* Adapt title and price typography size for 2-column mobile layout */
    .woocommerce ul.products li.product .efishop-card__title,
    .woocommerce-page ul.products li.product .efishop-card__title,
    .woocommerce ul.products li.product .efishop-card__title a,
    .woocommerce-page ul.products li.product .efishop-card__title a,
    .efishop-card__title {
        font-size: var(--text-title-sm) !important;
        margin: var(--space-1) 0 !important;
        line-height: 1.3 !important;
    }

    .woocommerce ul.products li.product .price,
    .woocommerce-page ul.products li.product .price,
    .woocommerce ul.products li.product .efishop-card__price,
    .woocommerce-page ul.products li.product .efishop-card__price {
        font-size: var(--text-title-md) !important;
        margin-bottom: var(--space-2) !important;
    }

    .woocommerce ul.products li.product .button,
    .woocommerce-page ul.products li.product .button,
    .woocommerce ul.products[class*="columns-"] li.product .button,
    .woocommerce-page ul.products[class*="columns-"] li.product .button {
        min-height: 38px !important;
        font-size: var(--text-label-sm) !important;
        padding: var(--space-2) var(--space-3) !important;
        white-space: normal !important;
        line-height: 1.2 !important;
        text-align: center !important;
        word-break: break-word !important;
    }
}

/* ============================================================
   EFISHOP — Cart Page Enhancements (v1.0.6)
   ============================================================ */

/* Quantity input visibility and modern design */
.woocommerce .quantity,
.woocommerce-page .quantity {
    display: inline-block !important;
    width: auto !important;
}

.woocommerce .quantity .qty,
.woocommerce-page .quantity .qty {
    width: 80px !important;
    height: 44px !important;
    padding: 0 var(--space-2) !important;
    text-align: center !important;
    border-radius: var(--radius-full) !important;
    background-color: var(--surface-container-high) !important;
    color: var(--on-surface) !important;
    border: 2px solid transparent !important;
    font-family: var(--font-body) !important;
    font-weight: 600 !important;
    font-size: var(--text-body-md) !important;
    appearance: textfield !important;
    -moz-appearance: textfield !important;
    box-shadow: none !important;
}

.woocommerce .quantity .qty:focus,
.woocommerce-page .quantity .qty:focus {
    border-color: rgba(0, 91, 194, 0.40) !important;
    background-color: var(--surface-container-lowest) !important;
}

/* Hide Spinners */
.woocommerce .quantity .qty::-webkit-outer-spin-button,
.woocommerce .quantity .qty::-webkit-inner-spin-button,
.woocommerce-page .quantity .qty::-webkit-outer-spin-button,
.woocommerce-page .quantity .qty::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

/* Coupon code input field layout and sizing */
.woocommerce-cart table.cart td.actions .coupon {
    display: inline-flex !important;
    align-items: center !important;
    gap: var(--space-3) !important;
    float: left !important;
}

.woocommerce-cart table.cart td.actions .coupon .input-text {
    width: 200px !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 var(--space-4) !important;
    height: 44px !important;
    border-radius: var(--radius-full) !important;
    box-sizing: border-box !important;
    background-color: var(--surface-container-high) !important;
    color: var(--on-surface) !important;
    border: 2px solid transparent !important;
}

.woocommerce-cart table.cart td.actions .coupon button {
    height: 44px !important;
    padding: 0 var(--space-6) !important;
    margin: 0 !important;
    border-radius: var(--radius-full) !important;
    font-size: var(--text-label-md) !important;
    font-weight: 700 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(145deg, var(--secondary), var(--secondary-dim)) !important;
    color: var(--on-secondary) !important;
    border: none !important;
    cursor: pointer !important;
}

/* Prevent cart-items from overflowing the grid columns */
.cart-items {
    min-width: 0 !important;
    overflow-x: auto !important;
}

/* Reset collaterals and cart totals floats and widths for laptop layouts */
.woocommerce-cart .cart-collaterals,
.woocommerce-page .cart-collaterals {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    background-color: var(--surface-container-lowest) !important;
    border-radius: var(--radius-xl) !important;
    padding: var(--space-6) !important;
    box-shadow: var(--shadow-ambient) !important;
    box-sizing: border-box !important;
}

/* ============================================================
   EFISHOP — Checkout Payment Methods (v1.0.7)
   ============================================================ */

/* Outer box spacing */
.woocommerce #payment ul.payment_methods {
    padding: var(--space-6) !important;
    list-style: none !important;
    margin: 0 !important;
}

/* Individual gateway row */
.woocommerce #payment ul.payment_methods li.wc_payment_method {
    margin-bottom: var(--space-5) !important;
    padding-bottom: var(--space-5) !important;
    border-bottom: 1px solid var(--outline-variant) !important;
    display: block !important;
}

.woocommerce #payment ul.payment_methods li.wc_payment_method:last-child {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
}

/* Radio input and Label alignment */
.woocommerce #payment ul.payment_methods li.wc_payment_method > input[type="radio"] {
    margin: 0 var(--space-3) 0 0 !important;
    vertical-align: middle !important;
    cursor: pointer !important;
    position: relative !important;
    top: -1px !important;
}

.woocommerce #payment ul.payment_methods li.wc_payment_method > label {
    display: inline-flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: var(--space-3) !important;
    font-weight: 700 !important;
    color: var(--on-surface) !important;
    cursor: pointer !important;
    vertical-align: middle !important;
    margin: 0 !important;
    font-size: var(--text-body-md) !important;
}

/* Gateway Logo Sizing */
.woocommerce #payment ul.payment_methods li.wc_payment_method > label img {
    max-height: 24px !important;
    width: auto !important;
    object-fit: contain !important;
    display: inline-block !important;
    vertical-align: middle !important;
    margin: 0 !important;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.05)) !important;
}

/* Selected Payment Description Box */
.woocommerce #payment div.payment_box {
    background-color: var(--surface-container-low) !important;
    border: 1px solid var(--outline-variant) !important;
    border-radius: var(--radius-xl) !important;
    padding: var(--space-6) !important;
    margin: var(--space-4) 0 !important;
    font-size: var(--text-body-sm) !important;
    color: var(--on-surface-variant) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.02) !important;
}

.woocommerce #payment div.payment_box p {
    margin: 0 !important;
    line-height: 1.6 !important;
}

/* Inside payment box media scaling */
.woocommerce #payment div.payment_box img,
.woocommerce #payment div.payment_box iframe {
    max-width: 100% !important;
    height: auto !important;
    border-radius: var(--radius-lg) !important;
    margin-top: var(--space-2) !important;
}

/* Checkout Place Order Area */
.woocommerce-checkout .place-order {
    padding: var(--space-6) !important;
    background-color: var(--surface-container-lowest) !important;
    border-top: 1px solid var(--outline-variant) !important;
}

.woocommerce-checkout .place-order .woocommerce-privacy-policy-text {
    font-size: var(--text-body-sm) !important;
    color: var(--on-surface-variant) !important;
    margin-bottom: var(--space-5) !important;
    line-height: 1.6 !important;
}

/* Terms and Conditions Checkbox Row */
.woocommerce-checkout .place-order .form-row.validate-required {
    display: flex !important;
    align-items: flex-start !important;
    gap: var(--space-3) !important;
    margin-bottom: var(--space-6) !important;
    padding: 0 !important;
}

.woocommerce-checkout .place-order .form-row.validate-required input[type="checkbox"] {
    margin-top: 5px !important;
    cursor: pointer !important;
    width: 16px !important;
    height: 16px !important;
}

.woocommerce-checkout .place-order .form-row.validate-required label {
    display: inline !important;
    font-size: var(--text-body-sm) !important;
    color: var(--on-surface) !important;
    cursor: pointer !important;
    line-height: 1.4 !important;
    font-weight: 500 !important;
}

/* Checkout Button Style */
.woocommerce-checkout .place-order button.button {
    width: 100% !important;
    min-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--space-3) var(--space-8) !important;
    font-size: var(--text-title-md) !important;
    font-weight: 700 !important;
    border-radius: var(--radius-full) !important;
    background: linear-gradient(145deg, var(--secondary), var(--secondary-dim)) !important;
    color: var(--on-secondary) !important;
    border: none !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    box-shadow: var(--shadow-ambient-sm) !important;
}

.woocommerce-checkout .place-order button.button:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--shadow-ambient) !important;
    background: linear-gradient(145deg, var(--secondary-dim), #004090) !important;
}

/* Hide the large trust banner on checkout page while keeping gateway icons */
.is-checkout .entry-content img:not(.wc-payment-gateway-icon):not(.payment_methods img):not(.product-thumbnail img) {
    display: none !important;
}

/* Footer Secure Payments Badge */
.footer-secure-payments {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: var(--space-4) 0 !important;
}

.footer-secure-payments__img {
    max-height: 28px !important;
    width: auto !important;
    display: block !important;
    opacity: 0.85 !important;
    transition: opacity var(--transition-fast) ease !important;
}

.footer-secure-payments__img:hover {
    opacity: 1 !important;
}

@media (min-width: 768px) {
    .footer-secure-payments {
        margin: 0 !important;
    }
}

/* ============================================================
   EFISHOP — Catalog Ordering & Search Form (v1.0.10)
   ============================================================ */

/* Catalog Ordering Selector Modernization */
.shop-toolbar select,
.woocommerce-ordering select {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234b5563' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    background-size: 14px !important;
    padding: var(--space-2) var(--space-10) var(--space-2) var(--space-5) !important;
    background-color: var(--surface-container-high) !important;
    border: 2px solid transparent !important;
    border-radius: var(--radius-full) !important;
    color: var(--on-surface) !important;
    font-family: var(--font-body) !important;
    font-weight: 600 !important;
    font-size: var(--text-label-md) !important;
    transition: all 0.2s ease !important;
    box-shadow: var(--shadow-ambient-sm) !important;
    cursor: pointer !important;
    width: auto !important;
    min-width: 180px !important;
}

.shop-toolbar select:focus,
.woocommerce-ordering select:focus {
    border-color: rgba(0, 91, 194, 0.40) !important;
    background-color: var(--surface-container-lowest) !important;
    box-shadow: 0 0 0 4px rgba(0, 91, 194, 0.08) !important;
}

/* Custom Search form inside overlay/general areas styling */
.search-form__wrapper {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
}

.search-form__wrapper .search-field {
    flex: 1 !important;
    padding-right: var(--space-12) !important; /* Make room for the button icon */
}

.search-submit-btn {
    position: absolute !important;
    right: 0 !important;
    background: none !important;
    border: none !important;
    color: var(--on-surface-variant) !important;
    cursor: pointer !important;
    padding: var(--space-2) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: color 0.2s ease !important;
    z-index: 2 !important;
}

.search-submit-btn:hover {
    color: var(--secondary) !important;
}

.search-submit-btn svg {
    display: block !important;
    stroke: currentColor !important;
}



