/**
 * MudMania WooCommerce Additional Styles
 * Loaded only on WooCommerce pages for performance.
 * @version 1.0.0
 */

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

.woocommerce div.product {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-8);
    padding: var(--sp-6) 0;
    max-width: var(--container);
    margin: 0 auto;
}

@media (min-width: 768px) {
    .woocommerce div.product {
        grid-template-columns: 1fr 1fr;
        align-items: start;
    }
}

@media (min-width: 1024px) {
    .woocommerce div.product {
        grid-template-columns: 50% 1fr;
        gap: var(--sp-12);
    }
}

/* Gallery */
.woocommerce div.product div.woocommerce-product-gallery {
    position: sticky;
    top: calc(var(--header-h) + var(--sp-4));
}

.woocommerce div.product div.woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
    background-color: var(--clr-surface);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--clr-border);
}

.woocommerce div.product .flex-control-thumbs {
    display: flex;
    gap: var(--sp-2);
    flex-wrap: wrap;
    margin-top: var(--sp-3);
}

.woocommerce div.product .flex-control-thumbs li {
    width: 72px;
    height: 72px;
    border-radius: var(--radius);
    overflow: hidden;
    border: 2px solid var(--clr-border);
    cursor: pointer;
    transition: border-color var(--trans-fast);
    flex-shrink: 0;
}

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

.woocommerce div.product .flex-control-thumbs li img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Summary */
.woocommerce div.product div.summary {
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
}

/* Category breadcrumb on product */
.woocommerce div.product .posted_in {
    font-size: var(--fs-xs);
    color: var(--clr-muted);
    text-transform: uppercase;
    letter-spacing: .08em;
}

.woocommerce div.product .posted_in a {
    color: var(--clr-accent);
    text-decoration: none;
}

/* SKU */
.woocommerce div.product .sku_wrapper {
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    padding: var(--sp-3) var(--sp-4);
    background-color: var(--clr-surface2);
    border-radius: var(--radius);
    display: inline-block;
}

.woocommerce div.product .sku {
    color: var(--clr-muted);
    font-weight: var(--fw-med);
}

/* Stock */
.woocommerce div.product .stock {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    padding: var(--sp-2) var(--sp-4);
    border-radius: var(--radius-full);
}

.woocommerce div.product .in-stock {
    background-color: rgba(34, 197, 94, 0.1);
    color: var(--clr-success);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.woocommerce div.product .out-of-stock {
    background-color: rgba(239, 68, 68, 0.1);
    color: var(--clr-danger);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    line-height: var(--lh-base);
    padding: var(--sp-4);
    background-color: var(--clr-surface2);
    border-radius: var(--radius);
    border-left: 3px solid var(--clr-accent);
}

.woocommerce div.product .woocommerce-product-details__short-description p {
    color: var(--clr-muted);
    margin-bottom: var(--sp-2);
}

.woocommerce div.product .woocommerce-product-details__short-description p:last-child {
    margin-bottom: 0;
}

/* Add to cart form */
.woocommerce div.product form.cart {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    flex-wrap: wrap;
}

.woocommerce div.product form.cart .quantity {
    display: flex;
    align-items: center;
    background-color: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius);
    overflow: hidden;
}

.woocommerce div.product form.cart div.quantity .quantity-minus,
.woocommerce div.product form.cart div.quantity .quantity-plus {
    width: 44px;
    height: 54px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--clr-muted);
    cursor: pointer;
    background: none;
    border: none;
    transition: all var(--trans-fast);
}

.woocommerce div.product form.cart div.quantity .quantity-minus:hover,
.woocommerce div.product form.cart div.quantity .quantity-plus:hover {
    color: var(--clr-accent);
    background-color: rgba(255,107,0,.12);
}

/* Product meta */
.woocommerce div.product .product_meta {
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    padding-top: var(--sp-4);
    border-top: 1px solid var(--clr-border);
}

.woocommerce div.product .product_meta span {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
}

.woocommerce div.product .product_meta a {
    color: var(--clr-accent);
    text-decoration: none;
}

.woocommerce div.product .product_meta a:hover {
    text-decoration: underline;
}

/* Share buttons */
.woocommerce div.product .woocommerce-share {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    flex-wrap: wrap;
    padding-top: var(--sp-4);
    border-top: 1px solid var(--clr-border);
}

.woocommerce div.product .woocommerce-share span {
    font-size: var(--fs-sm);
    color: var(--clr-muted);
}

/* =============================================================================
   BREADCRUMBS
   ============================================================================= */
.woocommerce-breadcrumb {
    color: var(--clr-muted);
    font-size: var(--fs-xs);
    margin-bottom: var(--sp-2);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--sp-1);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: var(--fw-semi);
}

.woocommerce-breadcrumb a {
    color: var(--clr-muted);
    text-decoration: none;
    transition: color var(--trans-fast);
}

.woocommerce-breadcrumb a:hover {
    color: var(--clr-accent);
}

/* =============================================================================
   SINGLE PRODUCT REDESIGN (MOCKUP POLISH)
   ============================================================================= */

.single-product #primary,
.single-product .site-main,
.single-product .content-area {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.single-product #content,
.single-product .site-content,
.single-product .col-full,
.single-product .site-main,
.single-product .site-main > .col-full,
.single-product .woocommerce-breadcrumb,
.single-product .woocommerce-notices-wrapper,
.single-product .woocommerce {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.single-product .col-full,
.single-product #content,
.single-product .site-content,
.single-product .site-main {
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box;
}

.single-product .woocommerce-breadcrumb,
.single-product .woocommerce-notices-wrapper,
.single-product .woocommerce {
    padding-left: 32px !important;
    padding-right: 32px !important;
    box-sizing: border-box;
}

@media (max-width: 767px) {
    .single-product .woocommerce-breadcrumb,
    .single-product .woocommerce-notices-wrapper,
    .single-product .woocommerce {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}

.single-product .woocommerce {
    max-width: 100% !important;
    margin: 0 !important;
    padding: var(--sp-8) 32px var(--sp-12) !important;
}

@media (min-width: 768px) {
    .single-product .woocommerce {
        padding-inline: 32px !important;
    }
}

.single-product .woocommerce div.product {
    width: 100%;
    display: flex !important;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: var(--sp-8);
}

.single-product .woocommerce div.product > * {
    min-width: 0;
    flex: 1 1 100%;
}

.single-product .woocommerce div.product div.images {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
}

.single-product .woocommerce div.product div.summary {
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
    max-width: 100% !important;
}

@media (min-width: 1024px) {
    .single-product .woocommerce div.product {
        gap: var(--sp-12);
    }

    .single-product .woocommerce div.product div.images,
    .single-product .woocommerce div.product div.woocommerce-product-gallery {
        flex: 0 0 calc(60% - (var(--sp-12) / 2));
        max-width: calc(60% - (var(--sp-12) / 2)) !important;
    }

    .single-product .woocommerce div.product div.summary {
        flex: 0 0 calc(40% - (var(--sp-12) / 2));
        max-width: calc(40% - (var(--sp-12) / 2)) !important;
    }
}

@media (min-width: 1024px) {
    .single-product div.product .images,
    .single-product div.product .woocommerce-product-gallery,
    .storefront-full-width-content.single-product div.product .images,
    .storefront-full-width-content.single-product div.product .woocommerce-product-gallery {
        width: 60% !important;
        max-width: 60% !important;
        float: left !important;
        margin-right: 0 !important;
    }

    .single-product div.product .summary,
    .storefront-full-width-content.single-product div.product .summary {
        width: 40% !important;
        max-width: 40% !important;
        float: right !important;
        margin-right: 0 !important;
    }
}

.single-product .woocommerce div.product div.woocommerce-product-gallery {
    top: calc(var(--header-h) + var(--sp-4));
    position: relative;
    width: 100%;
    max-width: none;
}

.single-product .woocommerce div.product span.onsale {
    position: absolute;
    top: var(--sp-4);
    left: var(--sp-4);
    z-index: 10;
    margin: 0;
    pointer-events: none;
}

.single-product .woocommerce div.product div.woocommerce-product-gallery .woocommerce-product-gallery__trigger {
    display: none;
}

.single-product .woocommerce div.product div.woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
    background: var(--clr-surface2);
    border-radius: var(--radius-lg);
    border: 1px solid var(--clr-border);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
}

.single-product .woocommerce div.product div.woocommerce-product-gallery .woocommerce-product-gallery__image a img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain;
    aspect-ratio: 1/1;
    padding: clamp(var(--sp-4), 1.9vw, var(--sp-8));
    display: block;
    margin: 0 auto;
}

.single-product .woocommerce div.product .flex-control-thumbs {
    gap: var(--sp-2);
    margin-top: var(--sp-3);
}

.single-product .woocommerce div.product .flex-control-thumbs li {
    width: 76px;
    height: 76px;
    border-radius: var(--radius-sm);
    border: 2px solid transparent;
    background: var(--clr-surface2);
    box-shadow: inset 0 0 0 1px var(--clr-border);
    transition: border-color var(--trans-fast);
}

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

.single-product .woocommerce div.product div.summary {
    gap: var(--sp-4);
    display: flex;
    flex-direction: column;
}

.single-product__eyebrow {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    margin-bottom: calc(var(--sp-2) * -1);
}

.single-product__eyebrow-chip {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: .45rem .85rem;
    border-radius: var(--radius-full);
    border: 1px solid var(--clr-border);
    background: rgba(255,255,255,.03);
    color: var(--clr-text);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: .08em;
    text-transform: uppercase;
}

.single-product__eyebrow-chip--accent {
    border-color: rgba(255,107,0,.4);
    background: rgba(255,107,0,.12);
    color: var(--clr-accent);
}

.single-product__eyebrow-chip--success {
    border-color: rgba(46,204,113,.35);
    background: rgba(46,204,113,.12);
    color: #9df0bc;
}

.single-product__eyebrow-chip--danger {
    border-color: rgba(232,64,64,.4);
    background: rgba(232,64,64,.12);
    color: #f88;
}

.single-product__eyebrow-chip--warning {
    border-color: rgba(255,193,7,.35);
    background: rgba(255,193,7,.10);
    color: #ffd76b;
}

.single-product__eyebrow-chip--muted {
    border-color: rgba(255,255,255,.1);
    background: rgba(255,255,255,.04);
    color: var(--clr-muted);
}

.single-product .woocommerce div.product .product_title {
    font-size: clamp(2rem, 3.5vw, 3rem);
    line-height: 1.1;
    letter-spacing: -.02em;
    margin-bottom: var(--sp-4);
    text-transform: capitalize;
}

.single-product .woocommerce div.product p.price,
.single-product .woocommerce div.product span.price,
.single-product .woocommerce div.product p.price .amount,
.single-product .woocommerce div.product span.price .amount {
    font-family: var(--ff-head);
    font-size: clamp(1.9rem, 3vw, 2.8rem);
    color: var(--clr-heading) !important;
    line-height: 1;
    margin-bottom: var(--sp-1);
    font-weight: var(--fw-bold);
    display: flex;
    align-items: baseline;
    gap: var(--sp-2);
}

.single-product .woocommerce div.product p.price del,
.single-product .woocommerce div.product span.price del {
    color: var(--clr-muted);
    font-size: clamp(1.1rem, 2vw, 1.5rem);
    margin-right: 0;
    text-decoration: line-through;
    font-weight: var(--fw-med);
}

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

.single-product .woocommerce div.product .woocommerce-product-details__short-description {
    background: var(--clr-surface2);
    border: 1px solid var(--clr-border);
    border-left: 3px solid var(--clr-accent);
    border-radius: var(--radius);
    padding: var(--sp-4);
    color: var(--clr-text);
    font-size: var(--fs-sm);
    line-height: var(--lh-base);
    margin-bottom: var(--sp-4);
}

.single-product__proof-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-3);
}

@media (min-width: 900px) {
    .single-product__proof-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1380px) {
    .single-product__proof-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.single-product__proof-card {
    display: flex;
    flex-direction: column;
    gap: .45rem;
    padding: var(--sp-4);
    border-radius: var(--radius);
    border: 1px solid var(--clr-border);
    background:
        radial-gradient(circle at top right, rgba(255,107,0,.14), transparent 42%),
        linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
    box-shadow: var(--shadow-sm);
}

.single-product__proof-kicker,
.single-product__support-kicker {
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--clr-accent);
}

.single-product__proof-card strong {
    color: var(--clr-heading);
    font-size: var(--fs-base);
    line-height: 1.35;
}

.single-product__proof-card span:last-child {
    color: var(--clr-muted);
    font-size: var(--fs-sm);
}

.single-product__highlights {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--sp-3);
}

@media (max-width: 520px) {
    .single-product__highlights {
        grid-template-columns: 1fr;
    }
}

.single-product__highlight-item {
    padding: var(--sp-4);
    border-radius: var(--radius);
    border: 1px solid var(--clr-border);
    background: var(--clr-surface2);
}

.single-product__highlight-label {
    display: block;
    margin-bottom: .35rem;
    color: var(--clr-muted);
    font-size: var(--fs-xs);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: var(--fw-bold);
}

.single-product__highlight-value {
    color: var(--clr-heading);
    font-size: var(--fs-base);
    line-height: 1.35;
}

.single-product__buybox {
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
    padding: clamp(var(--sp-4), 2vw, var(--sp-5));
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255,107,0,.26);
    background:
        radial-gradient(circle at top right, rgba(255,107,0,.16), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
    box-shadow: 0 18px 50px rgba(0,0,0,.28);
}

.single-product__buybox-head {
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.single-product__buybox-head strong {
    color: var(--clr-heading);
    font-size: var(--fs-lg);
    line-height: 1.2;
}

.single-product__buybox-head span {
    color: #d7d7d7;
    font-size: var(--fs-sm);
}

.single-product .woocommerce div.product form.cart {
    gap: var(--sp-3);
    margin-top: 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    background: rgba(0,0,0,.18);
    padding: 0;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

.single-product .woocommerce div.product form.cart .quantity {
    height: 52px;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    background: var(--clr-bg);
    overflow: hidden;
    display: flex;
    align-items: center;
}

.single-product .woocommerce div.product form.cart .quantity .qty {
    width: 64px;
    height: 52px;
    border: none;
    background: transparent;
    color: var(--clr-text);
    text-align: center;
}

.woocommerce div.product form.cart .button.single_add_to_cart_button {
    height: 52px;
    padding: 0 var(--sp-6);
    border-radius: var(--radius-sm);
    font-family: var(--ff-head);
    font-size: var(--fs-base);
    font-weight: var(--fw-bold);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #fff;
    background: linear-gradient(180deg, #ff8a2b 0%, var(--clr-accent) 72%);
    border: 1px solid rgba(255,107,0,.85);
    box-shadow: 0 4px 12px rgba(255,107,0,.24);
    transition: transform var(--trans-fast), box-shadow var(--trans-fast), filter var(--trans-fast);
    flex: 1;
    min-width: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.single-product__buybox-footer {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.single-product__buybox-footer span {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    min-height: 38px;
    padding: .5rem .8rem;
    border-radius: var(--radius-full);
    background: rgba(255,255,255,.04);
    border: 1px solid var(--clr-border);
    color: var(--clr-text);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: .06em;
    text-transform: uppercase;
}

.single-product__buybox-footer span::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--clr-accent);
    box-shadow: 0 0 12px rgba(255,107,0,.55);
}



/* USP Block */
.single-product__usp {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  padding: var(--sp-5);
  border-radius: var(--radius-lg);
  margin-top: var(--sp-6);
  box-shadow: var(--shadow-sm);
}
.single-product__usp-item {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  font-size: var(--fs-base);
  color: var(--clr-heading, var(--clr-white));
  font-weight: var(--fw-med);
}
.single-product__usp-item svg {
  color: var(--clr-accent);
  flex-shrink: 0;
  width: 24px;
  height: 24px;
}

.single-product__support-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}

@media (min-width: 768px) {
  .single-product__support-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.single-product__support-card {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  min-height: 100%;
  padding: var(--sp-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--clr-border);
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01)),
    var(--clr-surface2);
}

.single-product__support-card h3 {
  font-size: var(--fs-lg);
  line-height: 1.1;
}

.single-product__support-card p {
  color: var(--clr-muted);
  font-size: var(--fs-sm);
  max-width: none;
}

.single-product__mobile-cta {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 40;
    display: none;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    padding: .9rem 1rem calc(.9rem + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid rgba(255,255,255,.08);
    background: rgba(10,10,10,.94);
    backdrop-filter: blur(12px);
    box-shadow: 0 -12px 32px rgba(0,0,0,.35);
}

.single-product__mobile-cta-price {
    display: flex;
    flex-direction: column;
    gap: .15rem;
}

.single-product__mobile-cta-price span {
    color: var(--clr-muted);
    font-size: var(--fs-xs);
    text-transform: uppercase;
    letter-spacing: .08em;
}

.single-product__mobile-cta-price strong,
.single-product__mobile-cta-price .amount {
    color: var(--clr-heading);
    font-family: var(--ff-head);
    font-size: var(--fs-xl);
    line-height: 1;
}

.single-product__mobile-cta-button {
    min-width: 180px;
    color: #fff;
}

/* Sticky bar is hidden by default; JS adds .is-visible when ATC scrolls out of view */
@media (max-width: 767px) {
    .single-product .woocommerce {
        padding-bottom: calc(var(--sp-16) + 84px);
    }

    .single-product__mobile-cta.is-visible {
        display: flex;
    }
}

.woocommerce div.product form.cart .button.single_add_to_cart_button:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(255,107,0,.3);
    filter: saturate(1.08);
}

.single-product .woocommerce div.product .product_meta {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    gap: var(--sp-2) var(--sp-4);
    margin-top: var(--sp-6);
    padding-top: var(--sp-4);
    border-top: 1px solid var(--clr-border);
    color: var(--clr-muted);
    font-size: var(--fs-sm);
}

.single-product .woocommerce div.product .product_meta span {
    display: flex;
    align-items: baseline;
    gap: var(--sp-1);
    margin-right: 0;
}

.single-product .woocommerce div.product .product_meta .sku_wrapper,
.single-product .woocommerce div.product .product_meta .posted_in,
.single-product .woocommerce div.product .product_meta .tagged_as {
    display: inline-flex;
    align-items: baseline;
    background: var(--clr-surface2);
    padding: var(--sp-2) var(--sp-4);
    border-radius: var(--radius-full);
    border: 1px solid var(--clr-border);
    width: fit-content;
    white-space: nowrap;
}

.single-product .woocommerce div.product .product_meta .sku {
    color: var(--clr-heading);
    font-weight: var(--fw-bold);
}

.single-product .woocommerce div.product .product_meta a {
    color: var(--clr-accent);
    font-weight: var(--fw-semi);
    text-decoration: none;
    transition: color var(--trans-fast);
}

.single-product .woocommerce div.product .product_meta a:hover {
    color: var(--clr-accent-h);
}

.single-product .woocommerce div.product .woocommerce-tabs {
    grid-column: 1 / -1;
    margin-top: var(--sp-10);
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: var(--sp-2);
    border: none;
    padding: 0;
    margin: 0 0 var(--sp-4);
    overflow-x: auto;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs::before,
.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li::after {
    content: none;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li {
    border: 1px solid var(--clr-border);
    background: var(--clr-surface2);
    border-radius: var(--radius-sm);
    padding: 0;
    margin: 0;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: .65rem 1rem;
    font-family: var(--ff-head);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--clr-muted);
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li.active {
    border-color: var(--clr-accent) !important;
    background: var(--clr-surface) !important;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--clr-accent) !important;
}

.single-product .woocommerce div.product .woocommerce-tabs .panel {
    background: var(--clr-surface2);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius);
    padding: clamp(var(--sp-4), 2vw, var(--sp-6));
    color: var(--clr-text);
}

.single-product .woocommerce div.product .woocommerce-tabs .panel h2 {
    font-family: var(--ff-head);
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    margin-bottom: var(--sp-4);
    text-transform: uppercase;
}

.single-product .woocommerce div.product .woocommerce-tabs .panel p {
    max-width: 78ch;
}

.single-product .related.products,
.single-product .up-sells.upsells.products {
    margin-top: var(--sp-12);
    border-top: 1px solid var(--clr-border);
    padding-top: var(--sp-10);
    grid-column: 1 / -1;
}

.single-product .related.products > h2,
.single-product .up-sells.upsells.products > h2 {
    font-family: var(--ff-head);
    font-size: clamp(var(--fs-2xl), 3vw, var(--fs-3xl));
    margin-bottom: var(--sp-6);
    color: var(--clr-heading);
    text-transform: uppercase;
}

/* Related/upsell products as horizontal carousel */
.single-product .related.products ul.products,
.single-product .up-sells.upsells.products ul.products,
.mm-pdp-shell .related.products ul.products,
.mm-pdp-shell .upsells.products ul.products {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--sp-4);
    overflow-x: auto;
    overflow-y: hidden;
    padding: .25rem .25rem .75rem;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}

.single-product .related.products ul.products li.product,
.single-product .up-sells.upsells.products ul.products li.product,
.mm-pdp-shell .related.products ul.products li.product,
.mm-pdp-shell .upsells.products ul.products li.product {
    flex: 0 0 clamp(220px, 22vw, 300px);
    max-width: clamp(220px, 22vw, 300px);
    width: clamp(220px, 22vw, 300px);
    scroll-snap-align: start;
}

.single-product .related.products ul.products::-webkit-scrollbar,
.single-product .up-sells.upsells.products ul.products::-webkit-scrollbar,
.mm-pdp-shell .related.products ul.products::-webkit-scrollbar,
.mm-pdp-shell .upsells.products ul.products::-webkit-scrollbar {
    height: 8px;
}

.single-product .related.products ul.products::-webkit-scrollbar-thumb,
.single-product .up-sells.upsells.products ul.products::-webkit-scrollbar-thumb,
.mm-pdp-shell .related.products ul.products::-webkit-scrollbar-thumb,
.mm-pdp-shell .upsells.products ul.products::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,.24);
    border-radius: 999px;
}

/* Cleaner card look for related/upsell carousel */
.single-product .related.products .product-card,
.single-product .up-sells.upsells.products .product-card,
.mm-pdp-shell .related.products .product-card,
.mm-pdp-shell .upsells.products .product-card {
    background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 16px;
    overflow: hidden;
}

.single-product .related.products .product-card__image-wrapper,
.single-product .up-sells.upsells.products .product-card__image-wrapper,
.mm-pdp-shell .related.products .product-card__image-wrapper,
.mm-pdp-shell .upsells.products .product-card__image-wrapper {
    position: relative;
    aspect-ratio: 1 / 1;
    background: rgba(255,255,255,.025);
    border-bottom: 1px solid rgba(255,255,255,.08);
}

.single-product .related.products .product-card__image,
.single-product .up-sells.upsells.products .product-card__image,
.mm-pdp-shell .related.products .product-card__image,
.mm-pdp-shell .upsells.products .product-card__image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: .85rem;
}

.single-product .related.products .product-card__actions,
.single-product .up-sells.upsells.products .product-card__actions,
.single-product .related.products .product-card__sku,
.single-product .up-sells.upsells.products .product-card__sku,
.single-product .related.products .product-card__rating,
.single-product .up-sells.upsells.products .product-card__rating,
.single-product .related.products .product-card__compat,
.single-product .up-sells.upsells.products .product-card__compat,
.single-product .related.products .product-card__stock,
.single-product .up-sells.upsells.products .product-card__stock,
.single-product .related.products .product-card__quick-view,
.single-product .up-sells.upsells.products .product-card__quick-view,
.mm-pdp-shell .related.products .product-card__actions,
.mm-pdp-shell .upsells.products .product-card__actions,
.mm-pdp-shell .related.products .product-card__sku,
.mm-pdp-shell .upsells.products .product-card__sku,
.mm-pdp-shell .related.products .product-card__rating,
.mm-pdp-shell .upsells.products .product-card__rating,
.mm-pdp-shell .related.products .product-card__compat,
.mm-pdp-shell .upsells.products .product-card__compat,
.mm-pdp-shell .related.products .product-card__stock,
.mm-pdp-shell .upsells.products .product-card__stock,
.mm-pdp-shell .related.products .product-card__quick-view,
.mm-pdp-shell .upsells.products .product-card__quick-view {
    display: none !important;
}

.single-product .related.products .product-card__body,
.single-product .up-sells.upsells.products .product-card__body,
.mm-pdp-shell .related.products .product-card__body,
.mm-pdp-shell .upsells.products .product-card__body {
    padding: .8rem .9rem .6rem;
    gap: .45rem;
}

.single-product .related.products .product-card__brand,
.single-product .up-sells.upsells.products .product-card__brand,
.mm-pdp-shell .related.products .product-card__brand,
.mm-pdp-shell .upsells.products .product-card__brand {
    font-size: 10px;
    opacity: .8;
}

.single-product .related.products .product-card__name,
.single-product .up-sells.upsells.products .product-card__name,
.mm-pdp-shell .related.products .product-card__name,
.mm-pdp-shell .upsells.products .product-card__name {
    font-size: .92rem;
    line-height: 1.35;
    min-height: 2.5em;
    margin: 0;
}

.single-product .related.products .product-card__price,
.single-product .up-sells.upsells.products .product-card__price,
.mm-pdp-shell .related.products .product-card__price,
.mm-pdp-shell .upsells.products .product-card__price {
    font-size: 1.35rem;
    color: var(--clr-accent);
}

.single-product .related.products .product-card__footer,
.single-product .up-sells.upsells.products .product-card__footer,
.mm-pdp-shell .related.products .product-card__footer,
.mm-pdp-shell .upsells.products .product-card__footer {
    padding: 0 .9rem .9rem;
}

.single-product .related.products .product-card__add-to-cart,
.single-product .up-sells.upsells.products .product-card__add-to-cart,
.mm-pdp-shell .related.products .product-card__add-to-cart,
.mm-pdp-shell .upsells.products .product-card__add-to-cart {
    width: 100%;
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    padding: 0 .9rem;
    border-radius: 10px;
    border: 1px solid rgba(255,107,0,.85);
    background: linear-gradient(180deg, #ff8a2b 0%, var(--clr-accent) 70%);
    color: #fff;
    font-family: var(--ff-head);
    font-size: .82rem;
    font-weight: var(--fw-bold);
    letter-spacing: .06em;
    text-transform: uppercase;
}

.single-product .related.products .product-card__add-to-cart svg,
.single-product .up-sells.upsells.products .product-card__add-to-cart svg,
.mm-pdp-shell .related.products .product-card__add-to-cart svg,
.mm-pdp-shell .upsells.products .product-card__add-to-cart svg {
    width: 14px;
    height: 14px;
}

/* =============================================================================
   PRODUCT ATTRIBUTES TABLE
   ============================================================================= */

.woocommerce div.product .woocommerce-product-attributes {
    width: 100%;
    border-collapse: collapse;
}

.woocommerce div.product .woocommerce-product-attributes th {
    width: 40%;
    padding: var(--sp-3) var(--sp-4);
    background-color: var(--clr-surface2);
    border-bottom: 1px solid var(--clr-border);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    color: var(--clr-muted);
    text-align: left;
    vertical-align: top;
}

.woocommerce div.product .woocommerce-product-attributes td {
    padding: var(--sp-3) var(--sp-4);
    border-bottom: 1px solid var(--clr-border);
    font-size: var(--fs-sm);
    color: var(--clr-muted);
}

.woocommerce div.product .woocommerce-product-attributes tr:last-child th,
.woocommerce div.product .woocommerce-product-attributes tr:last-child td {
    border-bottom: none;
}

.woocommerce div.product .woocommerce-product-attributes td a {
    color: var(--clr-accent);
    text-decoration: none;
}

/* =============================================================================
   VARIABLE PRODUCT VARIATIONS
   ============================================================================= */

.woocommerce div.product form.variations_form table.variations {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 var(--sp-3);
    margin-bottom: var(--sp-4);
}

.woocommerce div.product form.variations_form table.variations td,
.woocommerce div.product form.variations_form table.variations th {
    padding: var(--sp-2) 0;
    border: none;
}

.woocommerce div.product form.variations_form table.variations td.label {
    padding-right: var(--sp-4);
    white-space: nowrap;
}

.woocommerce div.product form.variations_form table.variations label {
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    color: var(--clr-text);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.woocommerce div.product form.variations_form table.variations select {
    width: 100%;
    height: 48px;
    background-color: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    padding: 0 var(--sp-4);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    color: var(--clr-text);
    transition: border-color var(--trans-fast);
    appearance: none;
    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='%23FF6B00' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 48px;
    cursor: pointer;
}

.woocommerce div.product form.variations_form table.variations select:focus {
    border-color: var(--clr-accent);
    outline: none;
}

.woocommerce div.product form.variations_form .woocommerce-variation-description {
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    padding: var(--sp-3) var(--sp-4);
    background-color: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    margin-top: var(--sp-3);
    margin-bottom: var(--sp-3);
}

.woocommerce div.product form.variations_form .woocommerce-variation-price .price {
    font-family: var(--ff-head);
    font-size: var(--fs-2xl);
    font-weight: var(--fw-bold);
    color: var(--clr-heading, var(--clr-white));
    display: flex;
    align-items: baseline;
    gap: var(--sp-2);
}

.woocommerce div.product form.variations_form .woocommerce-variation-price .price del {
    color: var(--clr-muted);
    font-size: clamp(1.1rem, 2vw, 1.5rem);
    text-decoration: line-through;
    font-weight: var(--fw-med);
}

.woocommerce div.product form.variations_form .woocommerce-variation-price .price ins {
    color: var(--clr-accent);
    text-decoration: none;
}

.woocommerce div.product form.variations_form .reset_variations {
    font-size: var(--fs-xs);
    color: var(--clr-muted);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: var(--sp-1);
    transition: color var(--trans-fast);
}

.woocommerce div.product form.variations_form .reset_variations:hover {
    color: var(--clr-accent);
}

/* =============================================================================
   CART PAGE
   ============================================================================= */

/* .woocommerce-cart .woocommerce — defined in cart redesign section below */

.woocommerce table.shop_table.cart {
    width: 100%;
}

.woocommerce table.shop_table.cart .product-thumbnail img {
    width: 80px;
    height: 80px;
    object-fit: contain;
    border-radius: var(--radius);
    background-color: var(--clr-surface2);
    padding: var(--sp-1);
}

.woocommerce table.shop_table.cart .product-name a {
    font-weight: var(--fw-semi);
    color: var(--clr-text);
    text-decoration: none;
    transition: color var(--trans-fast);
}

.woocommerce table.shop_table.cart .product-name a:hover {
    color: var(--clr-accent);
}

.woocommerce table.shop_table.cart .product-remove a {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--clr-surface2);
    border-radius: var(--radius-sm);
    color: var(--clr-muted);
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    transition: all var(--trans-fast);
}

.woocommerce table.shop_table.cart .product-remove a:hover {
    background-color: var(--clr-danger);
    color: white;
}

.woocommerce .cart-collaterals .cart_totals table {
    border: none;
    background: transparent;
}

.woocommerce .cart-collaterals .cart_totals table th,
.woocommerce .cart-collaterals .cart_totals table td {
    border-bottom: 1px solid var(--clr-border);
    padding: var(--sp-3) 0;
}

.woocommerce .cart-collaterals .cart_totals .order-total .amount {
    font-family: var(--ff-head);
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--clr-accent);
}

.woocommerce .wc-proceed-to-checkout .checkout-button {
    height: 56px;
    font-size: var(--fs-md);
    border-radius: var(--radius);
    box-shadow: var(--shadow-accent);
}

/* =============================================================================
   CHECKOUT PAGE
   ============================================================================= */

.woocommerce-checkout .woocommerce {
    max-width: var(--container);
    margin: 0 auto;
    padding: var(--sp-8) var(--sp-4);
}

.woocommerce-checkout .col2-set {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-6);
}

@media (min-width: 768px) {
    .woocommerce-checkout .col2-set {
        grid-template-columns: 1fr 1fr;
    }
}

.woocommerce-checkout h3 {
    font-family: var(--ff-head);
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: var(--sp-5);
    padding-bottom: var(--sp-3);
    border-bottom: 2px solid var(--clr-accent);
    display: inline-block;
}

/* Payment methods */
.woocommerce-checkout .wc_payment_methods {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    margin-bottom: var(--sp-5);
}

.woocommerce-checkout .wc_payment_method {
    background-color: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-4);
    cursor: pointer;
    transition: border-color var(--trans-fast), background-color var(--trans-fast);
}

.woocommerce-checkout .wc_payment_method:has(input:checked) {
    border-color: var(--clr-accent);
    background-color: rgba(255,107,0,.12);
}

.woocommerce-checkout .wc_payment_method label {
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    font-weight: var(--fw-semi);
}

.woocommerce-checkout #place_order {
    width: 100%;
    height: 60px;
    font-size: var(--fs-lg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-accent);
}

/* =============================================================================
   MY ACCOUNT PAGE
   ============================================================================= */

.woocommerce-account .woocommerce {
    max-width: var(--container);
    margin: 0 auto;
    padding: var(--sp-8) var(--sp-4);
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    background-color: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--sp-6);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-4) var(--sp-5);
    font-size: var(--fs-sm);
    font-weight: var(--fw-med);
    color: var(--clr-muted);
    border-bottom: 1px solid var(--clr-border);
    text-decoration: none;
    transition: color var(--trans-fast), background-color var(--trans-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child a {
    border-bottom: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    color: var(--clr-accent);
    background-color: rgba(255,107,0,.12);
}

@media (min-width: 768px) {
    .woocommerce-account .woocommerce {
        display: grid;
        grid-template-columns: 240px 1fr;
        gap: var(--sp-8);
        align-items: start;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        position: sticky;
        top: calc(var(--header-h) + var(--sp-4));
        margin-bottom: 0;
    }
}

/* =============================================================================
   REVIEW FORM & COMMENTS
   ============================================================================= */

.woocommerce #reviews #comments h2 {
    font-size: var(--fs-2xl);
    color: var(--clr-heading);
    margin-bottom: var(--sp-6);
}

.woocommerce #reviews ol.commentlist {
    margin: 0;
    padding: 0;
    list-style: none;
}

.woocommerce #reviews ol.commentlist li {
    padding: var(--sp-6) 0;
    border-bottom: 1px solid var(--clr-border);
    margin: 0;
}

.woocommerce #reviews ol.commentlist li:last-child {
    border-bottom: none;
}

.woocommerce #reviews ol.commentlist li .comment_container {
    display: flex;
    gap: var(--sp-4);
}

.woocommerce #reviews ol.commentlist li img.avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--clr-surface2);
    border: 1px solid var(--clr-border);
    padding: 2px;
}

.woocommerce #reviews ol.commentlist li .comment-text {
    flex: 1;
    background: var(--clr-surface2);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius);
    padding: var(--sp-4);
}

.woocommerce #reviews ol.commentlist li .meta {
    font-size: var(--fs-xs);
    color: var(--clr-muted);
    margin-bottom: var(--sp-2);
}

.woocommerce #reviews ol.commentlist li .meta strong {
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    text-transform: uppercase;
}

.woocommerce .star-rating {
    font-size: var(--fs-xs);
    color: var(--clr-accent);
    margin-bottom: var(--sp-2);
}

.woocommerce #reviews #review_form_wrapper {
    background-color: var(--clr-surface2);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-6);
    margin-top: var(--sp-8);
}

.woocommerce #reviews #review_form_wrapper h3 {
    font-family: var(--ff-head);
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: .02em;
    margin-bottom: var(--sp-5);
    color: var(--clr-heading);
}

.woocommerce .comment-form-rating {
    margin-bottom: var(--sp-4);
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}

.woocommerce .comment-form-rating label {
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    margin: 0;
}

.woocommerce p.stars {
    margin: 0;
}

.woocommerce p.stars a {
    color: var(--clr-accent);
}

.woocommerce .comment-form-comment textarea,
.woocommerce .comment-form-author input,
.woocommerce .comment-form-email input {
    width: 100%;
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    color: var(--clr-text);
    padding: var(--sp-3);
    border-radius: var(--radius-sm);
    font-size: var(--fs-sm);
    transition: border-color var(--trans-fast);
}

.woocommerce .comment-form-comment textarea:focus,
.woocommerce .comment-form-author input:focus,
.woocommerce .comment-form-email input:focus {
    border-color: var(--clr-accent);
    outline: none;
}

/* =============================================================================
   PRODUCT LOOP IMPROVEMENTS
   ============================================================================= */

.woocommerce ul.products {
    margin: 0;
    padding: 0;
    list-style: none;
}

.woocommerce ul.products li.product {
    margin: 0;
    padding: 0;
    float: none;
    width: auto;
}

/* Override storefront product loop defaults */
.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product {
    list-style: none;
    position: relative;
}

/* Product gallery zoom overlay */
.pswp__bg { background: rgba(0, 0, 0, 0.95) !important; }

/* =============================================================================
   BUTTONS (Storefront overrides)
   ============================================================================= */
.woocommerce #respond input#submit, 
.woocommerce a.button, 
.woocommerce button.button, 
.woocommerce input.button {
  background-color: var(--clr-surface2);
  color: var(--clr-text);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  padding: .75rem 1.5rem;
  font-family: var(--ff-head);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: .05em;
  transition: all var(--trans-fast);
}

.woocommerce #respond input#submit:hover, 
.woocommerce a.button:hover, 
.woocommerce button.button:hover, 
.woocommerce input.button:hover {
  background-color: var(--clr-accent);
  color: #000;
  border-color: var(--clr-accent);
}

.woocommerce #respond input#submit.alt, 
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background: linear-gradient(180deg, #ff8a2b 0%, var(--clr-accent) 72%);
  color: #fff;
  border-color: rgba(255,107,0,.85);
}

.woocommerce #respond input#submit.alt:hover, 
.woocommerce a.button.alt:hover, 
.woocommerce button.button.alt:hover, 
.woocommerce input.button.alt:hover {
  background-color: var(--clr-accent-h);
  border-color: var(--clr-accent-h);
}

/* =============================================================================
   NOTICES & ALERTS
   ============================================================================= */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  background: var(--clr-surface) !important;
  border-top: none !important;
  border-left: 4px solid var(--clr-accent) !important;
  color: var(--clr-text) !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: var(--sp-4) var(--sp-4) var(--sp-4) var(--sp-10) !important;
  margin-bottom: var(--sp-6) !important;
  position: relative !important;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
  color: var(--clr-accent) !important;
  left: var(--sp-4) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

.woocommerce-error { border-left-color: var(--clr-danger) !important; }
.woocommerce-error::before { color: var(--clr-danger) !important; }

.woocommerce-message .button,
.woocommerce-info .button {
  float: right !important;
  margin-left: var(--sp-4) !important;
}

.woocommerce-store-notice,
.demo_store {
    background-color: var(--clr-accent) !important;
    color: white !important;
    font-size: var(--fs-sm);
    font-weight: var(--fw-med);
    padding: var(--sp-3) var(--sp-5);
    text-align: center;
}

.woocommerce-store-notice__dismiss-link {
    color: rgba(255,255,255,0.8) !important;
    margin-left: var(--sp-3);
}

/* =============================================================================
   LOADING OVERLAY
   ============================================================================= */

.blockUI.blockOverlay {
    background-color: rgba(10, 10, 10, 0.7) !important;
    backdrop-filter: blur(4px);
}

.blockUI.blockMsg {
    background-color: var(--clr-surface) !important;
    border: 1px solid var(--clr-border) !important;
    border-radius: var(--radius-lg) !important;
    color: var(--clr-text) !important;
}

/* WooCommerce loading spinner */
.woocommerce-form-login .woocommerce-form-login__submit,
.woocommerce-cart .cart_totals .wc-proceed-to-checkout,
.woocommerce-checkout #payment #place_order {
    position: relative;
}

/* =============================================================================
   COUPON FORM
   ============================================================================= */

.woocommerce-cart .coupon {
    display: flex;
    gap: var(--sp-3);
    flex-wrap: wrap;
}

.woocommerce-cart .coupon input#coupon_code {
    flex: 1;
    min-width: 200px;
    height: 44px;
    background-color: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius);
    padding: 0 var(--sp-4);
    font-size: var(--fs-sm);
    color: var(--clr-text);
    transition: border-color var(--trans-fast);
}

.woocommerce-cart .coupon input#coupon_code:focus {
    border-color: var(--clr-accent);
    box-shadow: 0 0 0 3px var(--shadow-accent);
    outline: none;
}


/* =============================================================================
   MM-CART — Custom Cart Page Layout
   ============================================================================= */

/* Page wrapper */
.woocommerce-cart .woocommerce {
    max-width: var(--container);
    margin-inline: auto;
    padding: var(--sp-8) var(--sp-4) var(--sp-16);
}

.mm-cart {
    display: flex;
    flex-direction: column;
    gap: var(--sp-6);
}

/* ── Header ── */
.mm-cart__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-4);
    flex-wrap: wrap;
}
.mm-cart__title {
    font-family: var(--ff-head);
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    font-weight: var(--fw-black);
    color: var(--clr-heading);
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    margin: 0;
}
.mm-cart__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    background: var(--clr-accent);
    color: #000;
    border-radius: var(--radius-full);
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    padding: 0 var(--sp-2);
}
.mm-cart__continue {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    text-decoration: none;
    transition: color var(--trans-fast);
}
.mm-cart__continue:hover { color: var(--clr-accent); }

/* ── Free shipping bar ── */
.mm-cart__shipping-bar {
    display: flex;
    align-items: center;
    gap: var(--sp-4);
    padding: var(--sp-3) var(--sp-5);
    border-bottom: 1px solid var(--clr-border);
}
.mm-cart__shipping-bar-msg {
    font-size: var(--fs-sm);
    color: rgba(255,255,255,0.5);
    margin: 0;
    white-space: nowrap;
}
.mm-cart__shipping-bar-msg strong {
    color: rgba(255,255,255,0.85);
    font-weight: 600;
}
.mm-cart__shipping-bar-msg--ok {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    color: var(--clr-success);
    font-weight: 600;
}
.mm-cart__shipping-bar-msg--ok strong { color: inherit; }
.mm-cart__shipping-bar-track {
    flex: 1;
    height: 3px;
    background: rgba(255,255,255,0.08);
    border-radius: 99px;
    overflow: hidden;
    min-width: 80px;
}
.mm-cart__shipping-bar-fill {
    height: 100%;
    background: var(--clr-accent);
    border-radius: 99px;
    transition: width .5s ease;
}

/* ── Main grid ── */
.mm-cart__grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: var(--sp-6);
    align-items: start;
}
@media (max-width: 1024px) {
    .mm-cart__grid { grid-template-columns: 1fr; }
    .mm-cart__summary { order: -1; }
}

/* ── Items (left column) ── */
.mm-cart__items {
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
}

/* Table */
.mm-cart__table {
    width: 100%;
    border-collapse: collapse;
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius);
    overflow: hidden;
}
.mm-cart__thead th {
    padding: var(--sp-3) var(--sp-4);
    font-family: var(--ff-head);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--clr-muted);
    text-align: left;
    background: var(--clr-surface2);
    border-bottom: 1px solid var(--clr-border);
}
.mm-cart__thead .mm-cart__col-price,
.mm-cart__thead .mm-cart__col-subtotal { text-align: right; }
.mm-cart__thead .mm-cart__col-qty { text-align: center; }

.mm-cart__row td {
    padding: var(--sp-4);
    border-bottom: 1px solid var(--clr-border);
    vertical-align: middle;
}
.mm-cart__row:last-child td { border-bottom: none; }

/* Thumbnail */
.mm-cart__col-thumb {
    width: 88px;
    padding-right: 0 !important;
}
.mm-cart__col-thumb img,
.mm-cart__col-thumb .mm-cart__thumb-link img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    border: 1px solid var(--clr-border);
    display: block;
    transition: opacity var(--trans-fast);
}
.mm-cart__col-thumb .mm-cart__thumb-link:hover img { opacity: .8; }

/* Product info */
.mm-cart__col-info { padding-left: var(--sp-3) !important; }
.mm-cart__product-name {
    font-weight: var(--fw-semi);
    font-size: var(--fs-sm);
    color: var(--clr-heading);
    line-height: var(--lh-snug);
    margin-bottom: var(--sp-1);
}
.mm-cart__product-name a {
    color: inherit;
    text-decoration: none;
    transition: color var(--trans-fast);
}
.mm-cart__product-name a:hover { color: var(--clr-accent); }
.mm-cart__product-sku {
    font-size: 11px;
    color: var(--clr-muted);
    margin-bottom: var(--sp-1);
}
.mm-cart__backorder {
    font-size: var(--fs-xs);
    color: #f59e0b;
    margin: var(--sp-1) 0 0;
}
.mm-cart__remove {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: var(--sp-2);
    font-size: 11px;
    color: var(--clr-muted);
    text-decoration: none;
    transition: color var(--trans-fast);
}
.mm-cart__remove:hover { color: var(--clr-danger); }

/* Price */
.mm-cart__col-price {
    text-align: right;
    white-space: nowrap;
    font-size: var(--fs-sm);
    color: var(--clr-text);
}
.mm-cart__col-price del { color: var(--clr-muted); font-size: 11px; text-decoration: line-through; }
.mm-cart__col-price ins { text-decoration: none; color: var(--clr-danger); }

/* Quantity */
.mm-cart__col-qty { text-align: center; }
.mm-cart__col-qty .quantity { display: inline-flex; }
.mm-cart__col-qty .quantity input[type=number] {
    width: 60px;
    height: 38px;
    background: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-text);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    text-align: center;
    -moz-appearance: textfield;
    transition: border-color var(--trans-fast);
}
.mm-cart__col-qty .quantity input[type=number]::-webkit-inner-spin-button,
.mm-cart__col-qty .quantity input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; }
.mm-cart__col-qty .quantity input[type=number]:focus {
    border-color: var(--clr-accent);
    outline: none;
}

/* Subtotal */
.mm-cart__col-subtotal {
    text-align: right;
    font-family: var(--ff-head);
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    white-space: nowrap;
}
.mm-cart__col-subtotal ins { text-decoration: none; }

/* ── Actions row ── */
.mm-cart__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    flex-wrap: wrap;
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius);
    padding: var(--sp-4);
}
.mm-cart__coupon { flex: 1; min-width: 260px; }
.mm-cart__coupon-wrap {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius-sm);
    overflow: hidden;
    transition: border-color var(--trans-fast);
}
.mm-cart__coupon-wrap:focus-within { border-color: var(--clr-accent); }
.mm-cart__coupon-wrap svg {
    flex-shrink: 0;
    margin-left: var(--sp-3);
    color: var(--clr-muted);
}
.mm-cart__coupon-input {
    flex: 1;
    height: 42px;
    padding: 0 var(--sp-3);
    background: transparent;
    border: none;
    color: var(--clr-text);
    font-size: var(--fs-sm);
    outline: none;
}
.mm-cart__coupon-input::placeholder { color: var(--clr-muted); }
.mm-cart__coupon-btn {
    height: 42px;
    padding: 0 var(--sp-4);
    background: var(--clr-surface);
    border: none;
    border-left: 1px solid var(--clr-border);
    color: var(--clr-accent);
    font-family: var(--ff-head);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: .06em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: background var(--trans-fast), color var(--trans-fast);
}
.mm-cart__coupon-btn:hover { background: var(--clr-accent); color: #000; }

.mm-cart__update-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    height: 42px;
    padding: 0 var(--sp-4);
    background: transparent;
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-muted);
    font-family: var(--ff-head);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: .06em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--trans-fast);
}
.mm-cart__update-btn:hover { border-color: var(--clr-accent); color: var(--clr-accent); }

/* ── Cross-sells ── */
.mm-cart__items .cross-sells > h2 {
    font-family: var(--ff-head);
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    margin-bottom: var(--sp-4);
}
.mm-cart__items .cross-sells ul.products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--sp-4);
    list-style: none;
    padding: 0;
    margin: 0;
}

/* ── Summary (right column) ── */
.mm-cart__summary {
    position: sticky;
    top: calc(var(--header-h) + var(--topbar-h, 0px) + var(--sp-4));
}

/* ── Cart totals panel ── */
.mm-cart-totals {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-5);
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
}
.mm-cart-totals__heading {
    font-family: var(--ff-head);
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    margin: 0;
    padding-bottom: var(--sp-3);
    border-bottom: 2px solid var(--clr-border);
}
.mm-cart-totals__table {
    width: 100%;
    border-collapse: collapse;
}
.mm-cart-totals__table tr th,
.mm-cart-totals__table tr td {
    padding: var(--sp-3) 0;
    border-bottom: 1px solid var(--clr-border);
    font-size: var(--fs-sm);
    vertical-align: middle;
}
.mm-cart-totals__table tr th {
    color: var(--clr-muted);
    text-align: left;
    font-weight: var(--fw-med);
}
.mm-cart-totals__table tr td {
    text-align: right;
    color: var(--clr-text);
    font-weight: var(--fw-semi);
}
.mm-cart-totals__table tr.order-total th,
.mm-cart-totals__table tr.order-total td {
    border-bottom: none;
    padding-top: var(--sp-4);
    padding-bottom: 0;
}
.mm-cart-totals__table tr.order-total th {
    font-family: var(--ff-head);
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    text-transform: uppercase;
    letter-spacing: .05em;
}
.mm-cart-totals__table tr.order-total td {
    font-family: var(--ff-head);
    font-size: var(--fs-2xl);
    font-weight: var(--fw-black);
    color: var(--clr-accent);
}
.mm-cart-totals__table tr.order-total .woocommerce-Price-amount {
    font-size: inherit;
    color: inherit;
}
.mm-cart-totals__tax-note {
    font-size: 11px;
    color: var(--clr-muted);
    margin: 0;
    text-align: right;
}

/* Checkout button */
.wc-proceed-to-checkout {
    margin-top: var(--sp-2);
}
.wc-proceed-to-checkout .checkout-button,
.wc-proceed-to-checkout a.checkout-button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--sp-2) !important;
    width: 100% !important;
    height: 54px !important;
    background: linear-gradient(180deg, #ff8a2b 0%, var(--clr-accent) 72%) !important;
    border: 2px solid rgba(255,107,0,.85) !important;
    border-radius: var(--radius-sm) !important;
    color: #fff !important;
    font-family: var(--ff-head) !important;
    font-size: var(--fs-base) !important;
    font-weight: var(--fw-black) !important;
    letter-spacing: .1em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    box-shadow: 0 4px 20px rgba(255,107,0,.35) !important;
    transition: all var(--trans-fast) !important;
    cursor: pointer !important;
}
.wc-proceed-to-checkout .checkout-button:hover,
.wc-proceed-to-checkout a.checkout-button:hover {
    background: linear-gradient(180deg, #ff9a44 0%, var(--clr-accent-dark, #cc5500) 72%) !important;
    border-color: var(--clr-accent-dark, #cc5500) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 28px rgba(255,107,0,.45) !important;
}

/* ── Trust badges ── */
.mm-cart-totals__trust {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-3);
    padding-top: var(--sp-3);
    border-top: 1px solid var(--clr-border);
}
.mm-cart-totals__trust-item {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: 11px;
    font-weight: var(--fw-semi);
    color: var(--clr-muted);
    letter-spacing: .03em;
}
.mm-cart-totals__trust-item svg { color: var(--clr-success); flex-shrink: 0; }

/* ── Mobile ── */
@media (max-width: 640px) {
    .mm-cart__thead .mm-cart__col-price,
    .mm-cart__thead .mm-cart__col-subtotal,
    .mm-cart__col-price,
    .mm-cart__col-subtotal { display: none; }
    .mm-cart__table { display: block; overflow-x: auto; }
    .mm-cart__actions { flex-direction: column; align-items: stretch; }
    .mm-cart__update-btn { width: 100%; justify-content: center; }
    .mm-cart-totals__trust { grid-template-columns: 1fr; }
}

/* =============================================================================
   SINGLE PRODUCT PAGE (mm-pdp-shell)
   NOTE: .woocommerce is on <body>, NOT a wrapper div — use body.single-product
   or .woocommerce div.product selectors, NOT .single-product .woocommerce ...
   ============================================================================= */

/* Container breadcrumb + notices — body is ancestor of these */
body.single-product .woocommerce-breadcrumb,
body.single-product .woocommerce-notices-wrapper {
    max-width: min(1200px, calc(100vw - 48px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Override the early display:grid rule on the product div */
.woocommerce div.product.mm-pdp-shell {
    display: block !important;
    float: none !important;
    width: min(1200px, calc(100vw - 48px)) !important;
    max-width: min(1200px, calc(100vw - 48px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: var(--sp-8) 0 var(--sp-12) !important;
}

.woocommerce div.product.mm-pdp-shell::before,
.woocommerce div.product.mm-pdp-shell::after {
    content: none !important;
}

.woocommerce div.product.mm-pdp-shell > * {
    float: none !important;
}

@media (max-width: 767px) {
    body.single-product .woocommerce-breadcrumb,
    body.single-product .woocommerce-notices-wrapper,
    .woocommerce div.product.mm-pdp-shell {
        width: calc(100vw - 32px) !important;
        max-width: calc(100vw - 32px) !important;
    }
}

/* Main PDP flex column */
.mm-pdp-shell .mm-pdp {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: clamp(2rem, 4vw, 4rem);
}

/* Hero: gallery + buy box */
.mm-pdp-shell .mm-pdp__hero {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: clamp(1.5rem, 3vw, 3rem);
    align-items: start;
}

@media (min-width: 960px) {
    .mm-pdp-shell .mm-pdp__hero {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    }
}

.mm-pdp-shell .mm-pdp__gallery-stage,
.mm-pdp-shell .mm-pdp__buy-stage {
    min-width: 0;
    width: 100%;
}

.mm-pdp-shell .mm-pdp__gallery-stage {
    position: relative;
    display: flex;
    flex-direction: column;
}

/* onsale badge — fix broken selector from earlier in this file; must be absolute
   so it doesn't push the gallery image down and misalign with the right column */
.mm-pdp-shell span.onsale {
    position: absolute !important;
    top: var(--sp-4) !important;
    left: var(--sp-4) !important;
    z-index: 10 !important;
    margin: 0 !important;
    pointer-events: none !important;
    width: 56px;
    height: 56px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(180deg, #ff5c3a 0%, #e84040 100%);
    color: #fff;
    font-family: var(--ff-head);
    font-size: .95rem;
    font-weight: var(--fw-bold);
    line-height: 1;
    text-align: center;
    box-shadow: 0 8px 16px rgba(232,64,64,.28);
}

@media (min-width: 960px) {
    .mm-pdp-shell .mm-pdp__buy-stage {
        position: sticky;
        top: calc(var(--header-h) + 1.5rem);
    }
}

/* Gallery */
.mm-pdp-shell div.woocommerce-product-gallery,
.mm-pdp-shell div.images {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    float: none !important;
    position: static !important; /* override the global sticky from line 91 */
}

.mm-pdp-shell div.woocommerce-product-gallery {
    position: relative;
    top: 0;
    padding: clamp(1rem, 2vw, 1.5rem);
    border-radius: 28px;
    border: 1px solid rgba(255,255,255,.07);
    background:
        radial-gradient(circle at top left, rgba(255,107,0,.12), transparent 30%),
        radial-gradient(circle at bottom right, rgba(255,255,255,.06), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
}

.mm-pdp-shell div.woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
    border: none;
    background: transparent;
    box-shadow: none;
}

.mm-pdp-shell div.woocommerce-product-gallery .woocommerce-product-gallery__image a {
    display: block;
    border-radius: 24px;
    overflow: hidden;
    background: #fff;
}

.mm-pdp-shell div.woocommerce-product-gallery .woocommerce-product-gallery__image a img {
    aspect-ratio: 1 / 1;
    object-fit: contain;
    padding: clamp(1rem, 2vw, 2rem);
}

.mm-pdp-shell .flex-control-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(82px, 96px));
    gap: .75rem;
    margin-top: 1rem;
}

.mm-pdp-shell .flex-control-thumbs li {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    border-radius: 16px;
    overflow: hidden;
}

/* Buy box / summary */
.mm-pdp-shell .mm-pdp__summary {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    float: none !important;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding: clamp(1.25rem, 2vw, 2rem);
    border-radius: 28px;
    border: 1px solid rgba(255,255,255,.08);
    background:
        radial-gradient(circle at top right, rgba(255,107,0,.12), transparent 32%),
        linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
    box-shadow: 0 28px 80px rgba(0,0,0,.22);
}

.mm-pdp-shell .product_title {
    font-size: clamp(2rem, 3vw, 3.8rem) !important;
    line-height: .96;
    max-width: none;
    margin-bottom: 0 !important;
}

.mm-pdp-shell .price,
.mm-pdp-shell .price .amount {
    font-size: clamp(2.1rem, 3vw, 3.25rem) !important;
    color: var(--clr-accent) !important;
    font-family: var(--ff-head) !important;
    font-weight: var(--fw-bold) !important;
}

.mm-pdp-shell .price del,
.mm-pdp-shell .price del .amount {
    color: var(--clr-muted) !important;
    font-size: .6em !important;
    font-weight: var(--fw-med) !important;
}

.mm-pdp-shell .price ins,
.mm-pdp-shell .price ins .amount {
    color: var(--clr-accent) !important;
    text-decoration: none !important;
}

.mm-pdp-shell .woocommerce-product-rating {
    margin-bottom: 0;
}

/* =============================================================================
   SHORT DESCRIPTION (buy column)
   ============================================================================= */

.mm-pdp-shell .woocommerce-product-details__short-description {
    margin-bottom: 0 !important;
    border: none !important;
    background: none !important;
    border-left: none !important;
    padding: 0 !important;
    box-shadow: none !important;
}

.mm-pdp-shell .woocommerce-product-details__short-description p {
    font-size: var(--fs-base);
    line-height: 1.75;
    color: var(--clr-text);
    margin-bottom: .75em;
}

.mm-pdp-shell .woocommerce-product-details__short-description p:last-child {
    margin-bottom: 0;
}

.mm-pdp-shell .woocommerce-product-details__short-description strong,
.mm-pdp-shell .woocommerce-product-details__short-description b {
    color: var(--clr-heading);
    font-weight: var(--fw-bold);
}

.mm-pdp-shell .woocommerce-product-details__short-description em {
    color: var(--clr-muted);
    font-style: italic;
}

.mm-pdp-shell .woocommerce-product-details__short-description ul {
    list-style: none;
    padding: 0;
    margin: .5em 0 .75em;
    display: flex;
    flex-direction: column;
    gap: .4em;
}

.mm-pdp-shell .woocommerce-product-details__short-description ul li {
    padding-left: 1.5em;
    position: relative;
    font-size: var(--fs-sm);
    color: var(--clr-text);
    line-height: 1.6;
}

.mm-pdp-shell .woocommerce-product-details__short-description ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: .55em;
    width: .5em;
    height: .5em;
    border-radius: 50%;
    background: var(--clr-accent);
    flex-shrink: 0;
}

/* Add to cart form */
.mm-pdp-shell form.cart {
    display: grid;
    grid-template-columns: auto minmax(220px, 1fr);
    gap: .9rem;
    align-items: stretch;
}

.mm-pdp-shell form.cart .single_add_to_cart_button {
    width: 100%;
    min-width: 0;
}

@media (max-width: 640px) {
    .mm-pdp-shell form.cart {
        grid-template-columns: 1fr;
    }
}

/* Proof / highlight grids */
.mm-pdp-shell .single-product__proof-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mm-pdp-shell .single-product__proof-card,
.mm-pdp-shell .single-product__highlight-item {
    min-width: 0;
}

.mm-pdp-shell .single-product__buybox {
    margin-top: .25rem;
}

/* Reassurance section: USP + support cards */
.mm-pdp-shell .mm-pdp__reassurance {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(1rem, 2vw, 2rem);
    align-items: start;
}

.mm-pdp-shell .single-product__usp {
    margin-top: 0;
    height: 100%;
}

.mm-pdp-shell .single-product__support-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Collapse all grids on tablet and below */
@media (max-width: 1024px) {
    .mm-pdp-shell .mm-pdp__hero,
    .mm-pdp-shell .mm-pdp__reassurance,
    .mm-pdp-shell .single-product__proof-grid,
    .mm-pdp-shell .single-product__support-grid {
        grid-template-columns: 1fr;
    }
}

/* Details section */
.mm-pdp-shell .mm-pdp__details {
    display: block;
    width: 100%;
}

.mm-pdp-shell .woocommerce-tabs,
.mm-pdp-shell .related.products,
.mm-pdp-shell .upsells.products {
    width: 100%;
    max-width: 100%;
}

/* Mobile adjustments */
@media (max-width: 767px) {
    .mm-pdp-shell .mm-pdp {
        gap: 1.5rem;
    }

    .mm-pdp-shell .mm-pdp__summary,
    .mm-pdp-shell div.woocommerce-product-gallery {
        border-radius: 20px;
        padding: 1rem;
    }

    .mm-pdp-shell .product_title {
        font-size: clamp(2rem, 10vw, 3.2rem) !important;
    }
}

/* ============================================================================
   SINGLE PRODUCT FALLBACK LAYOUT (non-mm-pdp templates)
   ============================================================================ */

.woocommerce div.product:not(.mm-pdp-shell) {
    display: grid !important;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: clamp(1.5rem, 3vw, 3.5rem) !important;
    width: min(1200px, calc(100vw - 48px)) !important;
    max-width: min(1200px, calc(100vw - 48px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.woocommerce div.product:not(.mm-pdp-shell) > * {
    min-width: 0;
}

.woocommerce div.product:not(.mm-pdp-shell) .images,
.woocommerce div.product:not(.mm-pdp-shell) .woocommerce-product-gallery,
.woocommerce div.product:not(.mm-pdp-shell) .summary {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

.woocommerce div.product:not(.mm-pdp-shell) .woocommerce-tabs,
.woocommerce div.product:not(.mm-pdp-shell) .related.products,
.woocommerce div.product:not(.mm-pdp-shell) .up-sells.upsells.products {
    grid-column: 1 / -1;
}

@media (max-width: 1024px) {
    .woocommerce div.product:not(.mm-pdp-shell) {
        grid-template-columns: 1fr;
    }
}

/* =============================================================================
   HIGH-SPECIFICITY OVERRIDES
   Storefront/WooCommerce has: .single-product div.product .summary { float: right !important }
   with specificity (0,3,1). These rules must beat that.
   ============================================================================= */

/* Beat Storefront float:right !important on summary (0,5,2 > 0,3,1) */
body.single-product div.product.mm-pdp-shell .summary.mm-pdp__summary {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Same for gallery */
body.single-product div.product.mm-pdp-shell .images.mm-pdp__gallery-stage,
body.single-product div.product.mm-pdp-shell div.woocommerce-product-gallery {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* =============================================================================
   MICRO-USP
   ============================================================================= */

.single-product__micro-usp {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: .75rem 1.25rem;
    border-top: 1px solid var(--clr-border);
    padding-top: 1rem;
}

.single-product__micro-usp li {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    line-height: 1.2;
}

.single-product__micro-usp svg {
    flex-shrink: 0;
    opacity: .7;
}

/* =============================================================================
   RATING LINK — clickable, scrolls to reviews
   ============================================================================= */

.mm-pdp-shell .woocommerce-product-rating {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.mm-pdp-shell .woocommerce-review-link {
    color: var(--clr-muted);
    font-size: var(--fs-sm);
    text-decoration: underline;
    text-underline-offset: 3px;
    cursor: pointer;
    transition: color var(--trans-fast);
}

.mm-pdp-shell .woocommerce-review-link:hover {
    color: var(--clr-text);
}

/* =============================================================================
   WOOCOMMERCE TABS → ACCORDIONS
   ============================================================================= */

/* Hide the default tab nav */
.mm-pdp-shell .woocommerce-tabs ul.tabs {
    display: none !important;
}

/* Each panel is hidden by default */
.mm-pdp-shell .woocommerce-tabs .woocommerce-Tabs-panel {
    display: none;
    border: none;
    padding: 1.25rem 0 .5rem;
    margin: 0;
    background: transparent;
    float: none;
}

.mm-pdp-shell .woocommerce-tabs .woocommerce-Tabs-panel.mm-accordion-open {
    display: block;
}

/* Accordion trigger button */
.mm-accordion-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 1rem 0;
    background: none;
    border: none;
    border-top: 1px solid rgba(255,255,255,.08);
    cursor: pointer;
    color: var(--clr-heading);
    font-family: var(--ff-head);
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    letter-spacing: .04em;
    text-transform: uppercase;
    text-align: left;
    transition: color var(--trans-fast);
}

.mm-accordion-trigger:hover {
    color: var(--clr-accent);
}

.mm-accordion-trigger svg {
    flex-shrink: 0;
    transition: transform .25s ease;
    opacity: .6;
}

.mm-accordion-trigger[aria-expanded="true"] svg {
    transform: rotate(180deg);
    opacity: 1;
}

/* Wrapper around the tabs area */
.mm-pdp-shell .woocommerce-tabs {
    border-bottom: 1px solid rgba(255,255,255,.08);
    margin-bottom: 2rem;
}

/* =============================================================================
   PROSE — long description, additional info, accordion panel content
   ============================================================================= */

.mm-pdp-shell .woocommerce-Tabs-panel,
.mm-pdp-shell .woocommerce-Tabs-panel > *:not(h2):not(table) {
    max-width: 72ch; /* optimal line length for readability */
}

/* Paragraphs */
.mm-pdp-shell .woocommerce-Tabs-panel p {
    font-size: var(--fs-base);
    line-height: 1.8;
    color: var(--clr-text);
    margin-bottom: 1.1em;
}

.mm-pdp-shell .woocommerce-Tabs-panel p:last-child {
    margin-bottom: 0;
}

/* Headings inside tabs */
.mm-pdp-shell .woocommerce-Tabs-panel h2 {
    display: none; /* WC repeats the tab name as h2 — hide it */
}

.mm-pdp-shell .woocommerce-Tabs-panel h3 {
    font-family: var(--ff-head);
    font-size: var(--fs-lg);
    font-weight: var(--fw-bold);
    color: var(--clr-heading);
    letter-spacing: .02em;
    margin: 1.75em 0 .6em;
    line-height: 1.25;
}

.mm-pdp-shell .woocommerce-Tabs-panel h3:first-child {
    margin-top: 0;
}

.mm-pdp-shell .woocommerce-Tabs-panel h4 {
    font-family: var(--ff-head);
    font-size: var(--fs-md);
    font-weight: var(--fw-semi);
    color: var(--clr-heading);
    letter-spacing: .03em;
    margin: 1.4em 0 .5em;
    text-transform: uppercase;
}

/* Inline emphasis */
.mm-pdp-shell .woocommerce-Tabs-panel strong,
.mm-pdp-shell .woocommerce-Tabs-panel b {
    color: var(--clr-heading);
    font-weight: var(--fw-bold);
}

.mm-pdp-shell .woocommerce-Tabs-panel em {
    color: var(--clr-muted);
    font-style: italic;
}

.mm-pdp-shell .woocommerce-Tabs-panel a {
    color: var(--clr-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: opacity var(--trans-fast);
}

.mm-pdp-shell .woocommerce-Tabs-panel a:hover {
    opacity: .8;
}

/* Unordered list — accent dot bullets */
.mm-pdp-shell .woocommerce-Tabs-panel ul {
    list-style: none;
    padding: 0;
    margin: .5em 0 1.25em;
    display: flex;
    flex-direction: column;
    gap: .55em;
}

.mm-pdp-shell .woocommerce-Tabs-panel ul li {
    padding-left: 1.6em;
    position: relative;
    font-size: var(--fs-base);
    color: var(--clr-text);
    line-height: 1.65;
}

.mm-pdp-shell .woocommerce-Tabs-panel ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: .65em;
    width: .45em;
    height: .45em;
    border-radius: 50%;
    background: var(--clr-accent);
}

/* Ordered list */
.mm-pdp-shell .woocommerce-Tabs-panel ol {
    list-style: none;
    counter-reset: prose-ol;
    padding: 0;
    margin: .5em 0 1.25em;
    display: flex;
    flex-direction: column;
    gap: .55em;
}

.mm-pdp-shell .woocommerce-Tabs-panel ol li {
    counter-increment: prose-ol;
    padding-left: 2em;
    position: relative;
    font-size: var(--fs-base);
    color: var(--clr-text);
    line-height: 1.65;
}

.mm-pdp-shell .woocommerce-Tabs-panel ol li::before {
    content: counter(prose-ol) '.';
    position: absolute;
    left: 0;
    top: 0;
    font-family: var(--ff-head);
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    color: var(--clr-accent);
    line-height: 1.65;
}

/* Blockquote / callout */
.mm-pdp-shell .woocommerce-Tabs-panel blockquote {
    border-left: 3px solid var(--clr-accent);
    background: rgba(255,107,0,.06);
    border-radius: 0 var(--radius) var(--radius) 0;
    padding: .85rem 1.25rem;
    margin: 1.25em 0;
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    font-style: normal;
}

.mm-pdp-shell .woocommerce-Tabs-panel blockquote p {
    margin-bottom: 0;
    font-size: inherit;
    color: inherit;
}

/* Images inside content */
.mm-pdp-shell .woocommerce-Tabs-panel img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius);
    display: block;
    margin: 1.25em 0;
}

/* Horizontal rule */
.mm-pdp-shell .woocommerce-Tabs-panel hr {
    border: none;
    border-top: 1px solid rgba(255,255,255,.08);
    margin: 1.75em 0;
}

/* =============================================================================
   SPECS TABLE (Additional Information tab)
   ============================================================================= */

.mm-pdp-shell .woocommerce-Tabs-panel table.shop_attributes,
.mm-pdp-shell .woocommerce-Tabs-panel table {
    width: 100%;
    max-width: 640px;
    border-collapse: collapse;
    font-size: var(--fs-sm);
    margin: 1em 0 1.5em;
}

.mm-pdp-shell .woocommerce-Tabs-panel table th,
.mm-pdp-shell .woocommerce-Tabs-panel table td {
    padding: .65rem 1rem;
    text-align: left;
    vertical-align: top;
    border: none;
    line-height: 1.5;
}

/* Label column (th) */
.mm-pdp-shell .woocommerce-Tabs-panel table th {
    color: var(--clr-muted);
    font-weight: var(--fw-semi);
    font-size: var(--fs-xs);
    letter-spacing: .05em;
    text-transform: uppercase;
    width: 40%;
    white-space: nowrap;
}

/* Value column (td) */
.mm-pdp-shell .woocommerce-Tabs-panel table td {
    color: var(--clr-heading);
    font-weight: var(--fw-med);
}

/* Alternating rows */
.mm-pdp-shell .woocommerce-Tabs-panel table tr:nth-child(odd) th,
.mm-pdp-shell .woocommerce-Tabs-panel table tr:nth-child(odd) td {
    background: rgba(255,255,255,.025);
}

.mm-pdp-shell .woocommerce-Tabs-panel table tr:nth-child(even) th,
.mm-pdp-shell .woocommerce-Tabs-panel table tr:nth-child(even) td {
    background: transparent;
}

/* Remove WC's default border */
.mm-pdp-shell .woocommerce-Tabs-panel table.shop_attributes tr th,
.mm-pdp-shell .woocommerce-Tabs-panel table.shop_attributes tr td {
    border: none;
}

/* =============================================================================
   PRODUCT VIDEO PLAYER
   ============================================================================= */

.mm-pdp-video {
    margin-top: 1rem;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.07);
    background: rgba(255,255,255,.03);
}

.mm-pdp-video__trigger {
    display: flex;
    align-items: center;
    gap: .75rem;
    width: 100%;
    padding: .85rem 1.25rem;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--clr-text);
    font-family: var(--ff-body);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    text-align: left;
    transition: background var(--trans-fast);
}

.mm-pdp-video__trigger:hover {
    background: rgba(255,255,255,.04);
}

.mm-pdp-video__play-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--clr-accent);
    color: #000;
    flex-shrink: 0;
    transition: transform var(--trans-fast);
}

.mm-pdp-video__trigger:hover .mm-pdp-video__play-icon {
    transform: scale(1.08);
}

.mm-pdp-video__player {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
}

.mm-pdp-video__player iframe,
.mm-pdp-video__player video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: none;
    display: block;
}

/* When player is visible, hide the trigger */
.mm-pdp-video.is-playing .mm-pdp-video__trigger {
    display: none;
}


/* ============================================================
   MM-CHECKOUT — 2-column conversion layout
   ============================================================ */

.mm-checkout {
    max-width: 1160px;
    margin: 0 auto;
    padding: var(--sp-6) var(--sp-4);
}

/* ── Head ── */
.mm-checkout__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--sp-4);
    gap: var(--sp-3);
    flex-wrap: wrap;
}

.mm-checkout__title {
    font-size: clamp(1.25rem, 3vw, 1.75rem);
    font-weight: var(--fw-bold);
    color: var(--clr-text);
    margin: 0;
}

.mm-checkout__back-to-cart {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    text-decoration: none;
    transition: color var(--trans-fast);
}

.mm-checkout__back-to-cart:hover {
    color: var(--clr-accent);
}

/* ── Trust bar ── */
.mm-checkout__trust-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-5);
    flex-wrap: wrap;
    padding: var(--sp-2) var(--sp-4);
    margin-bottom: var(--sp-5);
    background: var(--clr-surface2);
    border-radius: var(--radius);
    border: 1px solid var(--clr-border);
}

.mm-checkout__trust-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: var(--fw-semi);
    color: var(--clr-muted);
    white-space: nowrap;
}

.mm-checkout__trust-item svg {
    flex-shrink: 0;
    color: var(--clr-accent);
}

/* ── Form ── */
.mm-checkout__form {
    /* reset default WC form margins */
}

/* ── 2-column grid ── */
.mm-checkout__grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    align-items: start;
    gap: var(--sp-6);
}

/* ── LEFT – fields ── */
.mm-checkout__fields {
    min-width: 0;
}

.mm-checkout__logged-in {
    padding: var(--sp-2) var(--sp-3);
    margin-bottom: var(--sp-4);
    background: var(--clr-surface2);
    border-radius: var(--radius);
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    border-left: 3px solid var(--clr-accent);
}

.mm-checkout__section {
    margin-bottom: var(--sp-5);
}

.mm-checkout__section-title {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: 1rem;
    font-weight: var(--fw-bold);
    color: var(--clr-text);
    margin: 0 0 var(--sp-4);
    padding-bottom: var(--sp-2);
    border-bottom: 1px solid var(--clr-border);
}

.mm-checkout__section-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--clr-accent);
    color: #000;
    font-size: 13px;
    font-weight: var(--fw-bold);
    flex-shrink: 0;
}

/* WooCommerce customer details wrapper */
.mm-checkout__customer {
    /* flows normally */
}

/* Hide WC's own billing/shipping section headings — we render our own numbered headings */
.mm-checkout__fields .woocommerce-billing-fields > h3,
.mm-checkout__fields .woocommerce-shipping-fields > h3 {
    display: none;
}

/* Style the ship-to-different-address toggle inline */
.mm-checkout__fields #ship-to-different-address {
    margin-bottom: var(--sp-3);
    padding: var(--sp-2) 0;
    border-bottom: 1px solid var(--clr-border);
}

/* ── WC form fields inside checkout ── */
.mm-checkout__fields .woocommerce-billing-fields,
.mm-checkout__fields .woocommerce-shipping-fields,
.mm-checkout__fields .woocommerce-additional-fields {
    /* reset WC padding */
}

.mm-checkout__fields .form-row {
    margin-bottom: var(--sp-3);
}

.mm-checkout__fields .form-row label {
    display: block;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    color: var(--clr-text);
    margin-bottom: 6px;
}

.mm-checkout__fields .form-row input[type="text"],
.mm-checkout__fields .form-row input[type="email"],
.mm-checkout__fields .form-row input[type="tel"],
.mm-checkout__fields .form-row input[type="password"],
.mm-checkout__fields .form-row input[type="number"],
.mm-checkout__fields .form-row select,
.mm-checkout__fields .form-row textarea {
    width: 100%;
    height: 44px;
    padding: 0 var(--sp-3);
    background: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius);
    color: var(--clr-text);
    font-size: var(--fs-sm);
    font-family: var(--ff-body);
    transition: border-color var(--trans-fast), box-shadow var(--trans-fast);
    outline: none;
    appearance: none;
    -webkit-appearance: none;
}

.mm-checkout__fields .form-row textarea {
    height: auto;
    min-height: 90px;
    padding: var(--sp-2) var(--sp-3);
    resize: vertical;
}

.mm-checkout__fields .form-row input:focus,
.mm-checkout__fields .form-row select:focus,
.mm-checkout__fields .form-row textarea:focus {
    border-color: var(--clr-accent);
    box-shadow: 0 0 0 3px rgba(255,120,0,.15);
}

.mm-checkout__fields .form-row.woocommerce-invalid input,
.mm-checkout__fields .form-row.woocommerce-invalid select {
    border-color: #e53e3e;
}

.mm-checkout__fields .form-row.woocommerce-validated input,
.mm-checkout__fields .form-row.woocommerce-validated select {
    border-color: #38a169;
}

/* Select2 override */
.mm-checkout__fields .select2-container .select2-selection--single {
    height: 44px;
    background: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius);
}

.mm-checkout__fields .select2-container .select2-selection--single .select2-selection__rendered {
    line-height: 44px;
    color: var(--clr-text);
    font-size: var(--fs-sm);
    padding-left: var(--sp-3);
}

.mm-checkout__fields .select2-container .select2-selection--single .select2-selection__arrow {
    height: 42px;
}

.mm-checkout__fields .select2-container--open .select2-selection--single {
    border-color: var(--clr-accent);
    box-shadow: 0 0 0 3px rgba(255,120,0,.15);
}

/* Checkbox rows */
.mm-checkout__fields .woocommerce-form__label-for-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--fs-sm);
    cursor: pointer;
}

/* Ship to different address toggle */
#ship-to-different-address label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    cursor: pointer;
}

/* ── Payment section ── */
.mm-checkout__section--payment #order_review {
    /* WC renders the full payment block here */
}

/* Payment methods list */
.wc_payment_methods {
    list-style: none;
    margin: 0 0 var(--sp-4);
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}

.wc_payment_methods .wc_payment_method {
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: border-color var(--trans-fast);
}

.wc_payment_methods .wc_payment_method label {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    padding: var(--sp-3) var(--sp-3);
    cursor: pointer;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    color: var(--clr-text);
    transition: background var(--trans-fast);
}

.wc_payment_methods .wc_payment_method label:hover {
    background: var(--clr-surface2);
}

.wc_payment_methods .wc_payment_method input[type="radio"] {
    accent-color: var(--clr-accent);
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.wc_payment_methods .wc_payment_method input[type="radio"]:checked + label,
.wc_payment_methods .wc_payment_method:has(input:checked) {
    border-color: var(--clr-accent);
}

.payment_box {
    padding: var(--sp-3);
    background: var(--clr-surface2);
    font-size: var(--fs-sm);
    color: var(--clr-muted);
    border-top: 1px solid var(--clr-border);
}

/* Terms & conditions */
.woocommerce-terms-and-conditions-wrapper {
    margin-bottom: var(--sp-4);
    font-size: var(--fs-sm);
    color: var(--clr-muted);
}

/* Place order button */
#place_order,
.woocommerce-checkout #place_order {
    width: 100%;
    height: 52px;
    padding: 0 var(--sp-6);
    background: linear-gradient(180deg, #ff8a2b 0%, var(--clr-accent) 72%);
    border: none;
    border-radius: var(--radius);
    color: #fff;
    font-size: 1rem;
    font-weight: var(--fw-bold);
    font-family: var(--ff-body);
    cursor: pointer;
    letter-spacing: .02em;
    text-transform: uppercase;
    box-shadow: 0 4px 16px rgba(255,120,0,.35);
    transition: background var(--trans-fast), box-shadow var(--trans-fast), transform var(--trans-fast);
    display: block;
}

#place_order:hover {
    background: var(--clr-accent-h);
    box-shadow: 0 6px 20px rgba(255,120,0,.5);
    transform: translateY(-1px);
}

#place_order:active {
    transform: translateY(0);
}

/* ── RIGHT – sticky sidebar ── */
.mm-checkout__sidebar {
    position: sticky;
    top: calc(var(--header-h, 70px) + var(--topbar-h, 36px) + var(--sp-4));
}

.mm-checkout__order-summary {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg, 12px);
    overflow: hidden;
}

.mm-checkout__summary-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-4) var(--sp-4) var(--sp-3);
    font-size: 1rem;
    font-weight: var(--fw-bold);
    color: var(--clr-text);
    margin: 0;
    border-bottom: 1px solid var(--clr-border);
}

.mm-checkout__summary-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 2px 10px;
    border-radius: 100px;
    background: var(--clr-surface2);
    font-size: 12px;
    font-weight: var(--fw-semi);
    color: var(--clr-muted);
}

/* Cart items list */
.mm-checkout__summary-items {
    padding: var(--sp-3) var(--sp-4);
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    max-height: 280px;
    overflow-y: auto;
    border-bottom: 1px solid var(--clr-border);
    scrollbar-width: thin;
}

.mm-checkout__summary-item {
    display: grid;
    grid-template-columns: 48px 1fr auto;
    align-items: center;
    gap: var(--sp-2);
}

.mm-checkout__summary-thumb {
    position: relative;
    width: 48px;
    height: 48px;
    border-radius: 6px;
    overflow: hidden;
    background: var(--clr-surface2);
    flex-shrink: 0;
}

.mm-checkout__summary-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.mm-checkout__summary-qty {
    position: absolute;
    top: -6px;
    right: -6px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: 100px;
    background: var(--clr-accent);
    color: #000;
    font-size: 10px;
    font-weight: var(--fw-bold);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.mm-checkout__summary-info {
    min-width: 0;
}

.mm-checkout__summary-name {
    display: block;
    font-size: 13px;
    font-weight: var(--fw-semi);
    color: var(--clr-text);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
    margin-bottom: 2px;
}

.mm-checkout__summary-name:hover {
    color: var(--clr-accent);
}

.mm-checkout__summary-info .variation {
    font-size: 11px;
    color: var(--clr-muted);
    margin: 0;
}

.mm-checkout__summary-price {
    font-size: 13px;
    font-weight: var(--fw-bold);
    color: var(--clr-text);
    white-space: nowrap;
    text-align: right;
}

/* ── Coupon ── */
.mm-checkout__coupon {
    padding: var(--sp-3) var(--sp-4);
    border-bottom: 1px solid var(--clr-border);
}

.mm-checkout__coupon-wrap {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    background: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius);
    padding: 0 var(--sp-2) 0 var(--sp-3);
    transition: border-color var(--trans-fast);
}

.mm-checkout__coupon-wrap:focus-within {
    border-color: var(--clr-accent);
    box-shadow: 0 0 0 3px rgba(255,120,0,.12);
}

.mm-checkout__coupon-wrap svg {
    color: var(--clr-muted);
    flex-shrink: 0;
}

.mm-checkout__coupon-input {
    flex: 1;
    height: 38px;
    background: transparent;
    border: none;
    outline: none;
    color: var(--clr-text);
    font-size: var(--fs-sm);
    font-family: var(--ff-body);
    min-width: 0;
}

.mm-checkout__coupon-input::placeholder {
    color: var(--clr-muted);
}

.mm-checkout__coupon-btn {
    height: 30px;
    padding: 0 var(--sp-3);
    background: var(--clr-accent);
    border: none;
    border-radius: calc(var(--radius) - 2px);
    color: #000;
    font-size: 12px;
    font-weight: var(--fw-bold);
    font-family: var(--ff-body);
    cursor: pointer;
    white-space: nowrap;
    transition: background var(--trans-fast);
    flex-shrink: 0;
}

.mm-checkout__coupon-btn:hover {
    background: var(--clr-accent-h);
}

/* ── Totals ── */
.mm-checkout__summary-totals {
    padding: var(--sp-3) var(--sp-4);
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    border-bottom: 1px solid var(--clr-border);
}

.mm-checkout__summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: var(--fs-sm);
    color: var(--clr-muted);
}

.mm-checkout__summary-row span:last-child {
    font-weight: var(--fw-semi);
    color: var(--clr-text);
}

.mm-checkout__summary-row--discount {
    color: var(--clr-success, #38a169);
}

.mm-checkout__summary-row--discount span:last-child {
    color: var(--clr-success, #38a169);
}

.mm-checkout__summary-row--total {
    padding-top: var(--sp-2);
    border-top: 1px solid var(--clr-border);
    font-size: 1rem;
    color: var(--clr-text);
}

.mm-checkout__summary-row--total span:first-child {
    font-weight: var(--fw-bold);
    color: var(--clr-text);
}

.mm-checkout__summary-total-amt {
    font-size: 1.2rem;
    font-weight: var(--fw-bold);
    color: var(--clr-accent) !important;
}

.mm-checkout__free-ship {
    font-size: 11px;
    font-weight: var(--fw-bold);
    color: var(--clr-success, #38a169);
    background: rgba(56,161,105,.12);
    padding: 2px 6px;
    border-radius: 4px;
}

.mm-checkout__vat-note {
    font-size: 11px;
    color: var(--clr-muted);
    text-align: center;
    margin: var(--sp-1) 0 0;
}

/* ── Sidebar trust badge ── */
.mm-checkout__sidebar-trust {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: var(--sp-3) var(--sp-4);
    font-size: 12px;
    color: var(--clr-muted);
    background: var(--clr-surface2);
}

.mm-checkout__sidebar-trust svg {
    color: var(--clr-accent);
    flex-shrink: 0;
}

/* ── WC notices inside checkout ── */
.mm-checkout .woocommerce-error,
.mm-checkout .woocommerce-message,
.mm-checkout .woocommerce-info {
    border-radius: var(--radius);
    padding: var(--sp-3) var(--sp-4);
    font-size: var(--fs-sm);
    margin-bottom: var(--sp-3);
}

/* ── RESPONSIVE ── */

/* Tablet: narrower sidebar */
@media (max-width: 1100px) {
    .mm-checkout__grid {
        grid-template-columns: 1fr 320px;
        gap: var(--sp-4);
    }
}

/* Mobile: stack — sidebar on top, fields below */
@media (max-width: 768px) {
    .mm-checkout {
        padding: var(--sp-4) var(--sp-3);
    }

    .mm-checkout__grid {
        grid-template-columns: 1fr;
        gap: var(--sp-4);
    }

    /* Sidebar goes first on mobile (order summary before billing) */
    .mm-checkout__sidebar {
        order: -1;
        position: static;
    }

    .mm-checkout__summary-items {
        max-height: 200px;
    }

    .mm-checkout__trust-bar {
        gap: var(--sp-3);
        font-size: 11px;
    }

    .mm-checkout__trust-bar .mm-checkout__trust-item:nth-child(n+3) {
        /* Keep all 4 on mobile but allow wrap */
    }

    #place_order {
        height: 56px;
        font-size: 1rem;
    }
}

@media (max-width: 480px) {
    .mm-checkout__head {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--sp-2);
    }

    .mm-checkout__trust-bar {
        gap: var(--sp-2);
    }

    .mm-checkout__trust-item:last-child {
        display: none; /* Hide 4th badge on very small screens */
    }

    .mm-checkout__summary-item {
        grid-template-columns: 40px 1fr auto;
    }

    .mm-checkout__summary-thumb {
        width: 40px;
        height: 40px;
    }
}

/* ============================================================
   SELECT2 DROPDOWN – dark theme override (checkout + cart)
   ============================================================ */

.select2-dropdown {
    background: var(--clr-surface, #1a1a1a);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius);
    box-shadow: 0 8px 24px rgba(0,0,0,.4);
}

.select2-search--dropdown .select2-search__field {
    background: var(--clr-surface2);
    border: 1px solid var(--clr-border);
    border-radius: calc(var(--radius) - 2px);
    color: var(--clr-text);
    padding: 6px var(--sp-2);
    font-size: var(--fs-sm);
    outline: none;
}

.select2-results__option {
    padding: 8px var(--sp-3);
    font-size: var(--fs-sm);
    color: var(--clr-text);
    transition: background var(--trans-fast);
}

.select2-results__option--highlighted {
    background: var(--clr-accent) !important;
    color: #000 !important;
}

.select2-results__option[aria-selected="true"] {
    background: var(--clr-surface2);
    color: var(--clr-accent);
}

/* ── Native select arrow (fallback when Select2 not loaded) ── */
.mm-checkout__fields .form-row select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

/* ============================================================
   MY ACCOUNT — WooCommerce Overrides
   ============================================================ */

/* Orders table */
.woocommerce-orders-table {
    width: 100%;
    border-collapse: collapse;
}
.woocommerce-orders-table th {
    background: var(--clr-surface2);
    font-family: var(--ff-head);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: var(--sp-2) var(--sp-3);
    text-align: left;
    border-bottom: 1px solid var(--clr-border);
}
.woocommerce-orders-table td {
    padding: var(--sp-3);
    font-size: var(--fs-sm);
    border-bottom: 1px solid var(--clr-border);
    vertical-align: middle;
}
.woocommerce-orders-table .woocommerce-orders-table__cell-order-actions a {
    display: inline-block;
    padding: var(--sp-1) var(--sp-2);
    background: var(--clr-accent);
    color: #000;
    border-radius: var(--radius-sm);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: .04em;
    transition: background var(--trans-fast);
}
.woocommerce-orders-table .woocommerce-orders-table__cell-order-actions a:hover {
    background: var(--clr-accent-dark, #cc5500);
}

/* Account forms (edit-account, edit-address) */
.woocommerce-EditAccountForm .woocommerce-form-row,
.woocommerce-address-fields .woocommerce-input-wrapper {
    margin-bottom: var(--sp-4);
}
.woocommerce-EditAccountForm label,
.woocommerce-address-fields label {
    display: block;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    margin-bottom: var(--sp-1);
}
.woocommerce-EditAccountForm input[type="text"],
.woocommerce-EditAccountForm input[type="email"],
.woocommerce-EditAccountForm input[type="password"],
.woocommerce-address-fields input[type="text"],
.woocommerce-address-fields select {
    width: 100%;
    padding: var(--sp-2) var(--sp-3);
    background: var(--clr-surface2);
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-text);
    font-size: var(--fs-sm);
    transition: border-color var(--trans-fast);
}
.woocommerce-EditAccountForm input:focus,
.woocommerce-address-fields input:focus,
.woocommerce-address-fields select:focus {
    border-color: var(--clr-accent);
    outline: none;
    box-shadow: 0 0 0 3px rgba(255,107,0,.15);
}
.woocommerce-EditAccountForm .woocommerce-Button,
.woocommerce-address-fields .button {
    display: inline-flex;
    height: 48px;
    align-items: center;
    padding: 0 var(--sp-6);
    background: var(--clr-accent);
    color: #000;
    border: none;
    border-radius: var(--radius-sm);
    font-family: var(--ff-head);
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: .08em;
    cursor: pointer;
    transition: background var(--trans-fast);
}
.woocommerce-EditAccountForm .woocommerce-Button:hover,
.woocommerce-address-fields .button:hover {
    background: var(--clr-accent-dark, #cc5500);
}

/* Addresses grid */
.woocommerce-Addresses {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-4);
}
@media (max-width: 600px) {
    .woocommerce-Addresses { grid-template-columns: 1fr; }
}
.woocommerce-Addresses .woocommerce-Address {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius);
    padding: var(--sp-4);
}
.woocommerce-Addresses .woocommerce-Address-title h3 {
    font-family: var(--ff-head);
    font-size: var(--fs-base);
    font-weight: var(--fw-bold);
    margin-bottom: var(--sp-2);
}
.woocommerce-Addresses .woocommerce-Address-title a {
    color: var(--clr-accent);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
}

/* No orders — inherits notice styles from above (.woocommerce-info block) */
.woocommerce-info a {
    color: var(--clr-accent);
    font-weight: var(--fw-semi);
}

/* =============================================================================
   LIGHT MODE OVERRIDES
   ============================================================================= */

[data-theme="light"] {

  /* ── Eyebrow chips (dark rgba overrides) ── */
  .single-product__eyebrow-chip {
    background: rgba(0,0,0,.04);
  }
  .single-product__eyebrow-chip--accent { background: rgba(255,107,0,.1); }
  .single-product__eyebrow-chip--success { color: #16a34a; background: rgba(22,163,74,.08); }
  .single-product__eyebrow-chip--warning { color: #ca8a04; background: rgba(202,138,4,.08); }
  .single-product__eyebrow-chip--danger  { color: #dc2626; background: rgba(220,38,38,.08); }
  .single-product__eyebrow-chip--muted   { color: var(--clr-muted); background: rgba(0,0,0,.04); }

  /* ── Buybox & summary cards ── */
  .mm-pdp__summary,
  .single-product__proof-card {
    background: var(--clr-surface);
    border-color: var(--clr-border);
    box-shadow: var(--shadow-sm);
  }
  .single-product__proof-card {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
  }

  /* ── Product card actions ── */
  .product-card__quick-view,
  .product-card__action-btn {
    background: var(--clr-surface);
    color: var(--clr-text);
    border: 1px solid var(--clr-border);
  }

  /* ── Carousel cards ── */
  .mm-related-card,
  .mm-upsell-card {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
  }

  /* ── Mobile CTA bar ── */
  .single-product__mobile-cta {
    background: rgba(255,255,255,.94);
    border-top: 1px solid var(--clr-border);
    backdrop-filter: blur(12px);
  }

  /* ── WC notices ── */
  .woocommerce-message,
  .woocommerce-info,
  .woocommerce-error {
    background: var(--clr-surface);
    color: var(--clr-text);
    border-color: var(--clr-border);
  }

  /* ── Store notice ── */
  .demo_store,
  .woocommerce-store-notice {
    background: var(--clr-accent);
    color: #fff;
  }
  .demo_store a,
  .woocommerce-store-notice a {
    color: rgba(255,255,255,.9);
  }

  /* ── Buttons on accent bg keep white text ── */
  .single_add_to_cart_button,
  .checkout-button,
  .wc-proceed-to-checkout .checkout-button,
  .btn--primary {
    color: #fff;
  }

  /* ── Cart table ── */
  .mm-cart-table th {
    background: var(--clr-surface2);
    color: var(--clr-text);
  }

  /* ── Scrollbar (custom track) ── */
  .mm-pdp__buy-stage::-webkit-scrollbar-thumb {
    background: rgba(0,0,0,.15);
  }
  .mm-pdp__buy-stage::-webkit-scrollbar-track {
    background: rgba(0,0,0,.03);
  }

  /* ── Tabs section ── */
  .woocommerce-tabs {
    border-color: var(--clr-border);
  }

  /* ── rgba(255,255,255,...) → rgba(0,0,0,...) ── */
  .mm-pdp__summary-inner,
  .single-product__highlights,
  .single-product__micro-usp {
    border-color: var(--clr-border);
  }

  /* ── My Account ── */
  .mm-account__sidebar {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
  }

  /* ── Gallery ── */
  .woocommerce-product-gallery .flex-viewport,
  .woocommerce-product-gallery__image {
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
  }

  /* ── Video section ── */
  .mm-pdp__video-section {
    background: var(--clr-surface2);
    border: 1px solid var(--clr-border);
  }
}
