/*--------------------------------------------------------------
  Lift U Up — WooCommerce Style Overrides
  A premium, artisanal aesthetic for every WooCommerce view.
--------------------------------------------------------------*/

/* ==========================================================================
   0. BASE / RESETS
   ========================================================================== */

.woocommerce,
.woocommerce-page {
    font-family: var(--font-body);
    color: var(--ink);
    line-height: 1.6;
}

.woocommerce .container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ==========================================================================
   1. BREADCRUMBS
   ========================================================================== */

.woocommerce-breadcrumb {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.02em;
    color: var(--clay);
    padding: 20px 0;
    margin-bottom: 8px;
}

.woocommerce-breadcrumb a {
    color: var(--clay);
    text-decoration: none;
    transition: color 0.25s ease;
}

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

.woocommerce-breadcrumb .breadcrumb-sep {
    display: inline-block;
    margin: 0 8px;
    color: var(--old-gold);
    font-size: 14px;
}

/* ==========================================================================
   2. NOTICES & MESSAGES
   ========================================================================== */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    font-family: var(--font-body);
    font-size: 14px;
    padding: 16px 20px;
    margin-bottom: 24px;
    border-radius: 6px;
    border: none;
    line-height: 1.5;
    list-style: none;
}

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

.woocommerce-message {
    background: rgba(14, 107, 94, 0.08);
    border-left: 4px solid var(--peacock);
    color: var(--ink);
}

.woocommerce-info {
    background: rgba(212, 135, 63, 0.08);
    border-left: 4px solid var(--saffron);
    color: var(--ink);
}

.woocommerce-error {
    background: rgba(122, 31, 61, 0.08);
    border-left: 4px solid var(--rich-maroon);
    color: var(--ink);
}

.woocommerce-error li {
    list-style: none;
    margin-bottom: 4px;
}

.woocommerce-error li:last-child {
    margin-bottom: 0;
}

.woocommerce-message a,
.woocommerce-info a {
    color: var(--deep-indigo);
    font-weight: 500;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.25s ease;
}

.woocommerce-message a:hover,
.woocommerce-info a:hover {
    border-bottom-color: var(--saffron);
}

.woocommerce-message .button,
.woocommerce-info .button {
    float: right;
    margin-left: 16px;
}

/* ==========================================================================
   3. BUTTONS (GLOBAL)
   ========================================================================== */

.woocommerce .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 14px 32px;
    border: 2px solid var(--deep-indigo);
    border-radius: 4px;
    background: transparent;
    color: var(--deep-indigo);
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
    line-height: 1.4;
    text-align: center;
}

.woocommerce .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background: var(--deep-indigo);
    color: var(--ivory);
    border-color: var(--deep-indigo);
}

/* Primary / Alt buttons */
.woocommerce .button.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce .btn-primary,
.woocommerce a.btn-primary {
    background: var(--saffron);
    color: #fff;
    border-color: var(--saffron);
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 14px 32px;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
    line-height: 1.4;
    text-align: center;
}

.woocommerce .button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce .btn-primary:hover,
.woocommerce a.btn-primary:hover {
    background: var(--terracotta);
    border-color: var(--terracotta);
    color: #fff;
}

/* Disabled buttons */
.woocommerce .button:disabled,
.woocommerce .button.disabled,
.woocommerce .button:disabled[disabled],
.woocommerce a.button.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Added to cart button */
.woocommerce a.added_to_cart {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--peacock);
    text-decoration: none;
    padding: 6px 0;
    display: inline-block;
    transition: color 0.25s ease;
}

.woocommerce a.added_to_cart:hover {
    color: var(--deep-indigo);
}

/* ==========================================================================
   4. STAR RATINGS
   ========================================================================== */

.woocommerce .star-rating {
    color: var(--turmeric);
    font-size: 14px;
    overflow: hidden;
    position: relative;
    height: 1em;
    line-height: 1;
    width: 5.4em;
}

.woocommerce .star-rating::before {
    content: "\73\73\73\73\73";
    color: var(--jali);
    float: left;
    top: 0;
    left: 0;
    position: absolute;
}

.woocommerce .star-rating span {
    overflow: hidden;
    float: left;
    top: 0;
    left: 0;
    position: absolute;
    padding-top: 1.5em;
}

.woocommerce .star-rating span::before {
    content: "\53\53\53\53\53";
    color: var(--turmeric);
    top: 0;
    position: absolute;
    left: 0;
}

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

.woocommerce p.stars a::before {
    color: var(--turmeric);
}

.woocommerce p.stars a:hover ~ a::before {
    color: var(--jali);
}

/* ==========================================================================
   5. PRICE STYLING
   ========================================================================== */

.woocommerce .price,
.woocommerce .amount {
    font-family: var(--font-body);
    font-weight: 500;
    color: var(--deep-indigo);
}

.woocommerce .price del {
    opacity: 0.45;
    font-weight: 400;
    text-decoration: line-through;
    color: var(--clay);
    margin-right: 6px;
}

.woocommerce .price del .amount {
    color: var(--clay);
    font-weight: 400;
}

.woocommerce .price ins {
    text-decoration: none;
    font-weight: 600;
    color: var(--rich-maroon);
}

.woocommerce .price ins .amount {
    color: var(--rich-maroon);
    font-weight: 600;
}

.woocommerce .price .woocommerce-Price-currencySymbol {
    font-weight: 400;
    font-size: 0.85em;
    margin-right: 1px;
}

/* ==========================================================================
   6. SALE BADGE (product-tag override)
   ========================================================================== */

.woocommerce span.onsale,
.woocommerce .product-tag {
    font-family: var(--font-body);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
    background: var(--rich-maroon);
    padding: 5px 12px;
    border-radius: 3px;
    line-height: 1.4;
    display: inline-block;
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    min-height: auto;
    min-width: auto;
}

/* ==========================================================================
   7. SHOP / ARCHIVE PAGE
   ========================================================================== */

/* Page header */
.woocommerce-products-header {
    text-align: center;
    padding: 48px 0 32px;
}

.woocommerce-products-header__title {
    font-family: var(--font-display);
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 500;
    color: var(--deep-indigo);
    margin: 0 0 8px;
    letter-spacing: -0.01em;
}

.woocommerce-products-header .term-description {
    font-family: var(--font-body);
    font-size: 15px;
    color: var(--clay);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Category archive header */
.woocommerce-products-header .page-title {
    font-family: var(--font-display);
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 500;
    color: var(--deep-indigo);
}

/* Result count & ordering bar */
.woocommerce-result-count,
.woocommerce-ordering {
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--clay);
    margin-bottom: 24px;
}

.woocommerce .woocommerce-result-count {
    float: left;
    letter-spacing: 0.02em;
    line-height: 40px;
}

.woocommerce .woocommerce-ordering {
    float: right;
}

.woocommerce .woocommerce-ordering select {
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--ink);
    padding: 8px 36px 8px 14px;
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    background: #fff;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%232D2A26' stroke-width='1.2' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    cursor: pointer;
    transition: border-color 0.25s ease;
}

.woocommerce .woocommerce-ordering select:focus {
    outline: none;
    border-color: var(--saffron);
    box-shadow: 0 0 0 3px rgba(212, 135, 63, 0.12);
}

/* Product grid */
.woocommerce ul.products {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    list-style: none;
    padding: 0;
    margin: 0 0 48px;
    clear: both;
}

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

/* ==========================================================================
   8. PRODUCT CARDS (SHOP LOOP)
   ========================================================================== */

.woocommerce ul.products li.product {
    float: none;
    width: auto;
    margin: 0;
    padding: 0;
    text-align: left;
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--jali);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
    position: relative;
}

.woocommerce ul.products li.product:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(27, 23, 68, 0.1);
}

/* Product image */
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    margin: 0;
    border-radius: 0;
    transition: transform 0.5s ease;
}

.woocommerce ul.products li.product:hover a img {
    transform: scale(1.04);
}

.woocommerce ul.products li.product > a {
    display: block;
    overflow: hidden;
    position: relative;
    text-decoration: none;
    color: inherit;
}

/* Wishlist overlay (for YITH or custom) */
.woocommerce ul.products li.product .product-wishlist,
.woocommerce ul.products li.product .yith-wcwl-add-to-wishlist {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 3;
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(4px);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: translateY(-6px);
    transition: opacity 0.3s ease, transform 0.3s ease;
    cursor: pointer;
}

.woocommerce ul.products li.product:hover .product-wishlist,
.woocommerce ul.products li.product:hover .yith-wcwl-add-to-wishlist {
    opacity: 1;
    transform: translateY(0);
}

.woocommerce ul.products li.product .product-wishlist svg {
    width: 16px;
    height: 16px;
    color: var(--rich-maroon);
}

/* Product info area */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 500;
    color: var(--deep-indigo);
    padding: 16px 16px 4px;
    margin: 0;
    line-height: 1.35;
}

.woocommerce ul.products li.product .price {
    padding: 0 16px 4px;
    font-size: 15px;
}

.woocommerce ul.products li.product .star-rating {
    margin: 4px 16px 0;
}

/* Product origin meta in loop */
.woocommerce ul.products li.product .product-origin {
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--saffron);
    padding: 16px 16px 0;
    margin: 0;
}

/* Add to cart in loop */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button {
    margin: 12px 16px 16px;
    padding: 10px 20px;
    font-size: 12px;
    width: calc(100% - 32px);
    box-sizing: border-box;
}

/* ==========================================================================
   9. PAGINATION
   ========================================================================== */

.woocommerce nav.woocommerce-pagination {
    text-align: center;
    margin: 40px 0 60px;
}

.woocommerce nav.woocommerce-pagination ul {
    display: inline-flex;
    gap: 8px;
    border: none;
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce nav.woocommerce-pagination ul li {
    border: none;
    margin: 0;
    padding: 0;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    color: var(--ink);
    background: #fff;
    border: 1px solid rgba(27, 23, 68, 0.12);
    border-radius: 4px;
    text-decoration: none;
    transition: all 0.25s ease;
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
    border-color: var(--saffron);
    color: var(--saffron);
    background: rgba(212, 135, 63, 0.06);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--deep-indigo);
    border-color: var(--deep-indigo);
    color: #fff;
}

/* ==========================================================================
   10. SINGLE PRODUCT PAGE
   ========================================================================== */

.woocommerce div.product {
    padding: 24px 0 60px;
}

/* Two-column layout */
.woocommerce div.product div.images,
.woocommerce div.product div.summary {
    float: none;
}

.woocommerce div.product {
    display: grid;
    grid-template-columns: 55% 45%;
    gap: 48px;
    align-items: start;
}

/* Full-width rows inside the grid */
.woocommerce div.product .woocommerce-breadcrumb,
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related.products,
.woocommerce div.product .up-sells.upsells,
.woocommerce div.product .woocommerce-message,
.woocommerce div.product .woocommerce-info,
.woocommerce div.product .woocommerce-error {
    grid-column: 1 / -1;
}

/* Product gallery */
.woocommerce div.product div.images {
    width: 100%;
    position: sticky;
    top: 100px;
}

.woocommerce div.product div.images img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 8px;
}

.woocommerce div.product div.images .woocommerce-product-gallery__image {
    border-radius: 8px;
    overflow: hidden;
}

/* Gallery thumbnails */
.woocommerce div.product div.images .flex-control-thumbs {
    display: flex;
    gap: 10px;
    margin-top: 12px;
    padding: 0;
    list-style: none;
}

.woocommerce div.product div.images .flex-control-thumbs li {
    flex: 0 0 auto;
    width: 72px;
    height: 72px;
    overflow: hidden;
    border-radius: 6px;
    border: 2px solid transparent;
    transition: border-color 0.25s ease, opacity 0.25s ease;
    cursor: pointer;
    opacity: 0.6;
}

.woocommerce div.product div.images .flex-control-thumbs li:hover,
.woocommerce div.product div.images .flex-control-thumbs li .flex-active {
    border-color: var(--saffron);
    opacity: 1;
}

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

/* Sale badge on single product */
.woocommerce div.product span.onsale,
.woocommerce div.product .product-tag {
    top: 16px;
    left: 16px;
}

/* Summary / details column */
.woocommerce div.product div.summary {
    width: 100%;
    padding: 8px 0 0 0;
}

/* Product meta: origin */
.woocommerce div.product .liftuup-product-meta {
    margin-bottom: 12px;
}

.woocommerce div.product .liftuup-product-meta .product-origin {
    font-family: var(--font-body);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--saffron);
    margin-bottom: 2px;
}

/* Product title */
.woocommerce div.product .product_title {
    font-family: var(--font-display);
    font-size: clamp(24px, 3.5vw, 36px);
    font-weight: 500;
    color: var(--deep-indigo);
    margin: 0 0 16px;
    line-height: 1.2;
    letter-spacing: -0.01em;
}

/* Price on single product */
.woocommerce div.product .price {
    font-size: 22px;
    margin-bottom: 20px;
}

.woocommerce div.product .price del {
    font-size: 18px;
}

/* Rating on single */
.woocommerce div.product .woocommerce-product-rating {
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.woocommerce div.product .woocommerce-product-rating .woocommerce-review-link {
    font-size: 13px;
    color: var(--clay);
    text-decoration: none;
    transition: color 0.25s ease;
}

.woocommerce div.product .woocommerce-product-rating .woocommerce-review-link:hover {
    color: var(--saffron);
}

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
    font-size: 15px;
    line-height: 1.7;
    color: var(--ink);
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--jali);
}

/* Product meta (categories, tags, SKU) */
.woocommerce div.product .product_meta {
    font-size: 13px;
    color: var(--clay);
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--jali);
    line-height: 2;
}

.woocommerce div.product .product_meta > span {
    display: block;
}

.woocommerce div.product .product_meta a {
    color: var(--deep-indigo);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.25s ease;
}

.woocommerce div.product .product_meta a:hover {
    color: var(--saffron);
}

/* ==========================================================================
   11. QUANTITY INPUT
   ========================================================================== */

.woocommerce .quantity {
    display: inline-flex;
    align-items: center;
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    overflow: hidden;
    margin-right: 12px;
}

.woocommerce .quantity .qty {
    font-family: var(--font-body);
    font-size: 15px;
    font-weight: 500;
    color: var(--ink);
    width: 50px;
    height: 48px;
    text-align: center;
    border: none;
    background: #fff;
    appearance: textfield;
    -moz-appearance: textfield;
}

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

.woocommerce .quantity .qty:focus {
    outline: none;
    background: rgba(212, 135, 63, 0.04);
}

/* Quantity +/- buttons (if theme or plugin adds them) */
.woocommerce .quantity .minus,
.woocommerce .quantity .plus {
    width: 40px;
    height: 48px;
    font-size: 18px;
    font-weight: 300;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--warm-cream);
    color: var(--ink);
    border: none;
    cursor: pointer;
    transition: background 0.25s ease, color 0.25s ease;
}

.woocommerce .quantity .minus:hover,
.woocommerce .quantity .plus:hover {
    background: var(--saffron);
    color: #fff;
}

/* Add-to-cart button on single */
.woocommerce div.product form.cart {
    display: flex;
    align-items: center;
    gap: 0;
    margin-bottom: 24px;
    padding: 24px 0;
}

.woocommerce div.product form.cart .single_add_to_cart_button {
    background: var(--saffron);
    color: #fff;
    border-color: var(--saffron);
    padding: 14px 40px;
    font-size: 14px;
    flex-shrink: 0;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover {
    background: var(--terracotta);
    border-color: var(--terracotta);
}

/* Variation forms */
.woocommerce div.product form.cart .variations {
    width: 100%;
    margin-bottom: 16px;
    border: none;
}

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

.woocommerce div.product form.cart .variations label {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--ink);
}

.woocommerce div.product form.cart .variations select {
    font-family: var(--font-body);
    font-size: 14px;
    padding: 10px 14px;
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    background: #fff;
    color: var(--ink);
    min-width: 200px;
    transition: border-color 0.25s ease;
}

.woocommerce div.product form.cart .variations select:focus {
    outline: none;
    border-color: var(--saffron);
    box-shadow: 0 0 0 3px rgba(212, 135, 63, 0.12);
}

.woocommerce div.product form.cart .reset_variations {
    font-size: 12px;
    color: var(--clay);
    text-decoration: none;
    transition: color 0.25s ease;
}

.woocommerce div.product form.cart .reset_variations:hover {
    color: var(--rich-maroon);
}

/* ==========================================================================
   12. PRODUCT TABS
   ========================================================================== */

.woocommerce div.product .woocommerce-tabs {
    margin-top: 16px;
    padding-top: 48px;
    border-top: 1px solid var(--jali);
}

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

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

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

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

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--clay);
    padding: 12px 24px;
    display: block;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color 0.25s ease, border-color 0.25s ease;
    background: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--deep-indigo);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--deep-indigo);
    border-bottom-color: var(--saffron);
}

.woocommerce div.product .woocommerce-tabs .panel {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.7;
    color: var(--ink);
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 500;
    color: var(--deep-indigo);
    margin: 0 0 16px;
}

/* Reviews tab */
.woocommerce div.product .woocommerce-tabs #comments {
    margin: 0;
}

.woocommerce div.product .woocommerce-tabs .comment-text {
    border: 1px solid var(--jali);
    border-radius: 6px;
    padding: 16px 20px;
    margin: 0;
}

.woocommerce div.product .woocommerce-tabs .comment-text .meta {
    font-size: 13px;
    color: var(--clay);
    margin-bottom: 8px;
}

.woocommerce div.product .woocommerce-tabs .comment-text .meta strong {
    color: var(--deep-indigo);
}

.woocommerce div.product .woocommerce-tabs #review_form #respond textarea {
    font-family: var(--font-body);
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    padding: 12px 14px;
    transition: border-color 0.25s ease;
}

.woocommerce div.product .woocommerce-tabs #review_form #respond textarea:focus {
    outline: none;
    border-color: var(--saffron);
    box-shadow: 0 0 0 3px rgba(212, 135, 63, 0.12);
}

/* ==========================================================================
   13. RELATED PRODUCTS & UPSELLS
   ========================================================================== */

.woocommerce div.product .related.products,
.woocommerce div.product .up-sells.upsells {
    margin-top: 16px;
    padding-top: 48px;
    border-top: 1px solid var(--jali);
}

.woocommerce div.product .related.products > h2,
.woocommerce div.product .up-sells.upsells > h2 {
    font-family: var(--font-display);
    font-size: clamp(22px, 3vw, 30px);
    font-weight: 500;
    color: var(--deep-indigo);
    text-align: center;
    margin: 0 0 32px;
}

/* ==========================================================================
   14. CART PAGE
   ========================================================================== */

.woocommerce-cart .woocommerce {
    padding: 32px 0 60px;
}

/* Cart page title */
.woocommerce-cart .entry-title {
    font-family: var(--font-display);
    font-size: clamp(28px, 4vw, 38px);
    font-weight: 500;
    color: var(--deep-indigo);
    text-align: center;
    margin-bottom: 40px;
}

/* Cart table */
.woocommerce table.shop_table {
    border: 1px solid var(--jali);
    border-radius: 8px;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
    width: 100%;
    margin-bottom: 32px;
}

.woocommerce table.shop_table thead {
    background: var(--warm-cream);
}

.woocommerce table.shop_table thead th {
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--deep-indigo);
    padding: 14px 20px;
    border-bottom: 1px solid var(--jali);
}

.woocommerce table.shop_table tbody td {
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--ink);
    padding: 20px;
    border-bottom: 1px solid var(--jali);
    vertical-align: middle;
}

.woocommerce table.shop_table tbody tr:last-child td {
    border-bottom: none;
}

/* Cart product thumbnail */
.woocommerce table.shop_table .product-thumbnail {
    width: 90px;
}

.woocommerce table.shop_table .product-thumbnail img {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--jali);
}

/* Cart product name */
.woocommerce table.shop_table .product-name a {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 500;
    color: var(--deep-indigo);
    text-decoration: none;
    transition: color 0.25s ease;
}

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

/* Cart remove button */
.woocommerce table.shop_table .product-remove a.remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(122, 31, 61, 0.06);
    color: var(--rich-maroon);
    font-size: 18px;
    font-weight: 400;
    text-decoration: none;
    transition: all 0.25s ease;
}

.woocommerce table.shop_table .product-remove a.remove:hover {
    background: var(--rich-maroon);
    color: #fff;
}

/* Cart quantity */
.woocommerce table.shop_table .quantity .qty {
    width: 44px;
    height: 40px;
}

/* Cart actions row */
.woocommerce table.shop_table td.actions {
    padding: 20px;
    background: var(--warm-cream);
}

.woocommerce table.shop_table td.actions::after {
    content: '';
    display: table;
    clear: both;
}

/* Coupon form */
.woocommerce .cart .coupon {
    float: left;
    display: flex;
    gap: 8px;
    align-items: center;
}

.woocommerce .cart .coupon label {
    display: none;
}

.woocommerce .cart .coupon .input-text {
    font-family: var(--font-body);
    font-size: 14px;
    padding: 10px 14px;
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    background: #fff;
    color: var(--ink);
    min-width: 200px;
    transition: border-color 0.25s ease;
}

.woocommerce .cart .coupon .input-text::placeholder {
    color: var(--clay);
    opacity: 0.7;
}

.woocommerce .cart .coupon .input-text:focus {
    outline: none;
    border-color: var(--saffron);
    box-shadow: 0 0 0 3px rgba(212, 135, 63, 0.12);
}

.woocommerce .cart .coupon .button {
    padding: 10px 20px;
    font-size: 12px;
}

/* Update cart button */
.woocommerce table.shop_table td.actions > .button {
    float: right;
    padding: 10px 24px;
    font-size: 12px;
}

/* Cart totals */
.woocommerce .cart-collaterals {
    margin-top: 8px;
}

.woocommerce .cart_totals {
    float: right;
    width: 420px;
    max-width: 100%;
}

.woocommerce .cart_totals h2 {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 500;
    color: var(--deep-indigo);
    margin: 0 0 20px;
}

.woocommerce .cart_totals .shop_table {
    background: var(--warm-cream);
    border-radius: 8px;
    overflow: hidden;
}

.woocommerce .cart_totals .shop_table th {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--clay);
    padding: 16px 20px;
    width: 35%;
}

.woocommerce .cart_totals .shop_table td {
    font-size: 15px;
    font-weight: 500;
    color: var(--deep-indigo);
    padding: 16px 20px;
}

.woocommerce .cart_totals .shop_table .order-total td {
    font-size: 20px;
    font-weight: 600;
    color: var(--deep-indigo);
}

.woocommerce .cart_totals .wc-proceed-to-checkout {
    padding: 16px 0 0;
}

.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button {
    display: block;
    width: 100%;
    background: var(--saffron);
    color: #fff;
    border-color: var(--saffron);
    padding: 16px 32px;
    font-size: 15px;
    text-align: center;
    border-radius: 4px;
}

.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button:hover {
    background: var(--terracotta);
    border-color: var(--terracotta);
}

/* Empty cart */
.woocommerce .cart-empty {
    text-align: center;
    padding: 60px 20px;
    font-size: 16px;
    color: var(--clay);
}

.woocommerce .return-to-shop {
    text-align: center;
    margin-top: 24px;
}

/* ==========================================================================
   15. CHECKOUT PAGE
   ========================================================================== */

.woocommerce-checkout .woocommerce {
    padding: 32px 0 60px;
}

/* Checkout title */
.woocommerce-checkout .entry-title {
    font-family: var(--font-display);
    font-size: clamp(28px, 4vw, 38px);
    font-weight: 500;
    color: var(--deep-indigo);
    text-align: center;
    margin-bottom: 40px;
}

/* Two-column layout */
.woocommerce form.checkout {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 48px;
    align-items: start;
}

/* Full-width items inside checkout grid */
.woocommerce form.checkout .woocommerce-NoticeGroup,
.woocommerce form.checkout .woocommerce-checkout-review-order-table + *,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-error {
    grid-column: 1 / -1;
}

/* Billing / shipping fields */
.woocommerce form.checkout #customer_details {
    display: contents;
}

.woocommerce form.checkout #customer_details > div:first-child {
    grid-column: 1;
    grid-row: 1;
}

.woocommerce form.checkout #customer_details > div:last-child {
    grid-column: 1;
    grid-row: 2;
}

/* Order review column */
.woocommerce form.checkout .woocommerce-checkout-review-order {
    grid-column: 2;
    grid-row: 1 / span 3;
    position: sticky;
    top: 100px;
}

/* Checkout section headings */
.woocommerce-checkout h3,
.woocommerce form.checkout h3 {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 500;
    color: var(--deep-indigo);
    margin: 0 0 24px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--jali);
}

/* Form fields */
.woocommerce form .form-row {
    margin-bottom: 16px;
}

.woocommerce form .form-row label {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--ink);
    margin-bottom: 6px;
    display: block;
}

.woocommerce form .form-row label .required {
    color: var(--rich-maroon);
    text-decoration: none;
    border: none;
}

.woocommerce form .form-row .input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout #payment .input-text {
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--ink);
    width: 100%;
    padding: 12px 14px;
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    background: #fff;
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
    box-sizing: border-box;
}

.woocommerce form .form-row .input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    outline: none;
    border-color: var(--saffron);
    box-shadow: 0 0 0 3px rgba(212, 135, 63, 0.12);
}

.woocommerce form .form-row .input-text::placeholder,
.woocommerce form .form-row textarea::placeholder {
    color: var(--clay);
    opacity: 0.6;
}

.woocommerce form .form-row.woocommerce-invalid .input-text {
    border-color: var(--rich-maroon);
}

.woocommerce form .form-row.woocommerce-validated .input-text {
    border-color: var(--peacock);
}

/* Select2 dropdowns (WooCommerce uses Select2) */
.woocommerce .select2-container--default .select2-selection--single {
    font-family: var(--font-body);
    font-size: 14px;
    height: 46px;
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    padding: 0 14px;
    display: flex;
    align-items: center;
}

.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--ink);
    line-height: 44px;
    padding: 0;
}

.woocommerce .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 44px;
    right: 10px;
}

.woocommerce .select2-container--default.select2-container--focus .select2-selection--single,
.woocommerce .select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--saffron);
    box-shadow: 0 0 0 3px rgba(212, 135, 63, 0.12);
}

.select2-dropdown {
    font-family: var(--font-body);
    border: 1px solid rgba(27, 23, 68, 0.15);
    border-radius: 4px;
    box-shadow: 0 8px 24px rgba(27, 23, 68, 0.1);
}

.select2-results__option--highlighted {
    background: var(--saffron) !important;
    color: #fff !important;
}

/* Order review table */
.woocommerce-checkout-review-order-table {
    background: var(--warm-cream);
    border-radius: 8px;
    overflow: hidden;
}

.woocommerce-checkout-review-order-table thead th {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--deep-indigo);
    background: rgba(27, 23, 68, 0.04);
}

.woocommerce-checkout-review-order-table tfoot th {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--clay);
}

.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
    font-size: 18px;
    font-weight: 600;
    color: var(--deep-indigo);
}

/* Payment methods */
.woocommerce-checkout #payment {
    background: var(--warm-cream);
    border-radius: 8px;
    padding: 24px;
    margin-top: 24px;
}

.woocommerce-checkout #payment ul.payment_methods {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    border-bottom: 1px solid var(--jali);
}

.woocommerce-checkout #payment ul.payment_methods li {
    padding: 16px 0;
    border-top: 1px solid var(--jali);
}

.woocommerce-checkout #payment ul.payment_methods li:first-child {
    border-top: none;
}

.woocommerce-checkout #payment ul.payment_methods li label {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    color: var(--deep-indigo);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
}

.woocommerce-checkout #payment ul.payment_methods li label img {
    max-height: 24px;
    margin-left: 8px;
}

.woocommerce-checkout #payment ul.payment_methods li .payment_box {
    font-size: 13px;
    color: var(--clay);
    padding: 12px 0 4px 24px;
    background: none;
    line-height: 1.5;
}

.woocommerce-checkout #payment ul.payment_methods li .payment_box::before {
    display: none;
}

/* Place order button */
.woocommerce-checkout #payment #place_order {
    width: 100%;
    background: var(--saffron);
    color: #fff;
    border: 2px solid var(--saffron);
    padding: 16px 32px;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.woocommerce-checkout #payment #place_order:hover {
    background: var(--terracotta);
    border-color: var(--terracotta);
}

/* Checkout privacy policy text */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
    font-size: 13px;
    color: var(--clay);
    margin-bottom: 16px;
}

.woocommerce-checkout .woocommerce-privacy-policy-text {
    font-size: 12px;
    color: var(--clay);
}

.woocommerce-checkout .woocommerce-privacy-policy-text a {
    color: var(--deep-indigo);
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* Login / coupon toggle forms on checkout */
.woocommerce-form-login-toggle,
.woocommerce-form-coupon-toggle {
    margin-bottom: 20px;
}

.woocommerce form.checkout_coupon,
.woocommerce form.login {
    border: 1px solid var(--jali);
    border-radius: 8px;
    padding: 24px;
    margin-bottom: 24px;
}

/* ==========================================================================
   16. MY ACCOUNT PAGE
   ========================================================================== */

.woocommerce-account .woocommerce {
    padding: 32px 0 60px;
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 48px;
    align-items: start;
}

/* Full-width items */
.woocommerce-account .woocommerce > .woocommerce-message,
.woocommerce-account .woocommerce > .woocommerce-info,
.woocommerce-account .woocommerce > .woocommerce-error {
    grid-column: 1 / -1;
}

/* Account title */
.woocommerce-account .entry-title {
    font-family: var(--font-display);
    font-size: clamp(28px, 4vw, 38px);
    font-weight: 500;
    color: var(--deep-indigo);
    grid-column: 1 / -1;
    margin-bottom: 8px;
}

/* Navigation sidebar */
.woocommerce-MyAccount-navigation {
    background: var(--warm-cream);
    border-radius: 8px;
    overflow: hidden;
    position: sticky;
    top: 100px;
}

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

.woocommerce-MyAccount-navigation ul li {
    margin: 0;
    border-bottom: 1px solid var(--jali);
}

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

.woocommerce-MyAccount-navigation ul li a {
    display: block;
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 400;
    color: var(--ink);
    padding: 14px 20px;
    text-decoration: none;
    transition: all 0.25s ease;
    border-left: 3px solid transparent;
}

.woocommerce-MyAccount-navigation ul li a:hover {
    background: rgba(212, 135, 63, 0.06);
    color: var(--saffron);
    border-left-color: var(--saffron);
}

.woocommerce-MyAccount-navigation ul li.is-active a {
    font-weight: 500;
    color: var(--deep-indigo);
    background: rgba(27, 23, 68, 0.04);
    border-left-color: var(--deep-indigo);
}

/* Account content area */
.woocommerce-MyAccount-content {
    min-height: 400px;
}

.woocommerce-MyAccount-content p {
    font-size: 15px;
    line-height: 1.7;
    color: var(--ink);
}

.woocommerce-MyAccount-content p a {
    color: var(--deep-indigo);
    font-weight: 500;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.25s ease;
}

.woocommerce-MyAccount-content p a:hover {
    border-bottom-color: var(--saffron);
}

/* Account section headings */
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
    font-family: var(--font-display);
    font-weight: 500;
    color: var(--deep-indigo);
}

/* Order table */
.woocommerce-MyAccount-content .woocommerce-orders-table,
.woocommerce-MyAccount-content .shop_table {
    width: 100%;
}

.woocommerce-MyAccount-content .woocommerce-orders-table thead th {
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    background: var(--warm-cream);
}

.woocommerce-MyAccount-content .woocommerce-orders-table .button {
    padding: 8px 16px;
    font-size: 12px;
}

/* Account form fields */
.woocommerce-MyAccount-content .woocommerce-EditAccountForm .form-row label,
.woocommerce-MyAccount-content .woocommerce-address-fields .form-row label {
    font-size: 13px;
    font-weight: 500;
}

.woocommerce-MyAccount-content fieldset {
    border: 1px solid var(--jali);
    border-radius: 8px;
    padding: 24px;
    margin: 24px 0;
}

.woocommerce-MyAccount-content fieldset legend {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 500;
    color: var(--deep-indigo);
    padding: 0 8px;
}

/* Login / Register forms */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
    border: 1px solid var(--jali);
    border-radius: 8px;
    padding: 32px;
    max-width: 480px;
}

/* When not logged in, center the form */
.woocommerce-account .woocommerce:not(:has(.woocommerce-MyAccount-navigation)) {
    display: block;
}

.woocommerce-account .u-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
}

/* ==========================================================================
   17. WIDGETS (SIDEBAR / FILTERS)
   ========================================================================== */

/* Base widget styling */
.woocommerce .widget {
    margin-bottom: 32px;
}

.woocommerce .widget .widget-title,
.woocommerce .widget .widgettitle {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 500;
    color: var(--deep-indigo);
    margin: 0 0 16px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--jali);
}

/* Product categories widget */
.woocommerce .widget_product_categories ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce .widget_product_categories ul li {
    margin: 0;
}

.woocommerce .widget_product_categories ul li a {
    display: block;
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--ink);
    padding: 8px 0;
    text-decoration: none;
    border-bottom: 1px solid var(--jali);
    transition: color 0.25s ease, padding-left 0.25s ease;
}

.woocommerce .widget_product_categories ul li a:hover {
    color: var(--saffron);
    padding-left: 6px;
}

.woocommerce .widget_product_categories ul li .count {
    float: right;
    font-size: 12px;
    color: var(--clay);
    background: var(--warm-cream);
    padding: 2px 8px;
    border-radius: 10px;
}

/* Sub-categories */
.woocommerce .widget_product_categories ul li ul {
    padding-left: 16px;
}

/* Layered navigation (attribute filters) */
.woocommerce .widget_layered_nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce .widget_layered_nav ul li {
    margin: 0;
}

.woocommerce .widget_layered_nav ul li a {
    display: block;
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--ink);
    padding: 8px 0;
    text-decoration: none;
    border-bottom: 1px solid var(--jali);
    transition: color 0.25s ease;
}

.woocommerce .widget_layered_nav ul li a:hover {
    color: var(--saffron);
}

.woocommerce .widget_layered_nav ul li.chosen a {
    font-weight: 500;
    color: var(--deep-indigo);
}

.woocommerce .widget_layered_nav ul li.chosen a::before {
    content: '✓';
    display: inline-block;
    margin-right: 6px;
    color: var(--peacock);
    font-size: 12px;
}

.woocommerce .widget_layered_nav ul li .count {
    float: right;
    font-size: 12px;
    color: var(--clay);
}

/* Price filter widget */
.woocommerce .widget_price_filter .price_slider_wrapper {
    padding: 8px 0;
}

.woocommerce .widget_price_filter .ui-slider {
    background: var(--jali);
    border: none;
    height: 4px;
    border-radius: 2px;
    margin-bottom: 16px;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
    background: var(--saffron);
    border-radius: 2px;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--saffron);
    top: -7px;
    cursor: grab;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle:hover,
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle:active {
    box-shadow: 0 2px 10px rgba(212, 135, 63, 0.3);
    transform: scale(1.1);
}

.woocommerce .widget_price_filter .price_slider_amount {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 8px;
}

.woocommerce .widget_price_filter .price_slider_amount .price_label {
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--ink);
}

.woocommerce .widget_price_filter .price_slider_amount .button {
    padding: 8px 16px;
    font-size: 12px;
}

/* Active filters widget */
.woocommerce .widget_layered_nav_filters ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.woocommerce .widget_layered_nav_filters ul li a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--deep-indigo);
    background: var(--warm-cream);
    padding: 6px 12px;
    border-radius: 20px;
    text-decoration: none;
    transition: background 0.25s ease;
}

.woocommerce .widget_layered_nav_filters ul li a:hover {
    background: rgba(122, 31, 61, 0.1);
    color: var(--rich-maroon);
}

/* Product list widget */
.woocommerce .widget_products ul,
.woocommerce .widget_recent_reviews ul,
.woocommerce .widget_top_rated_products ul,
.woocommerce .widget_recently_viewed_products ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce .widget_products ul li,
.woocommerce .widget_recent_reviews ul li,
.woocommerce .widget_top_rated_products ul li,
.woocommerce .widget_recently_viewed_products ul li {
    display: flex;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--jali);
    align-items: center;
}

.woocommerce .widget_products ul li:last-child,
.woocommerce .widget_recent_reviews ul li:last-child,
.woocommerce .widget_top_rated_products ul li:last-child,
.woocommerce .widget_recently_viewed_products ul li:last-child {
    border-bottom: none;
}

.woocommerce .widget_products ul li img,
.woocommerce .widget_recent_reviews ul li img,
.woocommerce .widget_top_rated_products ul li img,
.woocommerce .widget_recently_viewed_products ul li img {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 4px;
    flex-shrink: 0;
}

.woocommerce .widget_products ul li a,
.woocommerce .widget_top_rated_products ul li a,
.woocommerce .widget_recently_viewed_products ul li a {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    color: var(--deep-indigo);
    text-decoration: none;
    transition: color 0.25s ease;
}

.woocommerce .widget_products ul li a:hover,
.woocommerce .widget_top_rated_products ul li a:hover,
.woocommerce .widget_recently_viewed_products ul li a:hover {
    color: var(--saffron);
}

/* Rating filter widget */
.woocommerce .widget_rating_filter ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce .widget_rating_filter ul li a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    text-decoration: none;
    border-bottom: 1px solid var(--jali);
    transition: opacity 0.25s ease;
}

.woocommerce .widget_rating_filter ul li a:hover {
    opacity: 0.75;
}

.woocommerce .widget_rating_filter ul li.chosen a {
    font-weight: 500;
}

/* ==========================================================================
   18. RESPONSIVE
   ========================================================================== */

@media screen and (max-width: 1024px) {

    /* Shop grid: 2 columns on tablets */
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }

    /* Single product: stack columns */
    .woocommerce div.product {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .woocommerce div.product div.images {
        position: static;
    }

    /* Checkout: stack columns */
    .woocommerce form.checkout {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .woocommerce form.checkout .woocommerce-checkout-review-order {
        grid-column: 1;
        grid-row: auto;
        position: static;
    }

    /* My Account: stack columns */
    .woocommerce-account .woocommerce {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .woocommerce-MyAccount-navigation {
        position: static;
    }

    .woocommerce-MyAccount-navigation ul {
        display: flex;
        flex-wrap: wrap;
        gap: 0;
    }

    .woocommerce-MyAccount-navigation ul li {
        border-bottom: none;
        border-right: 1px solid var(--jali);
    }

    .woocommerce-MyAccount-navigation ul li:last-child {
        border-right: none;
    }

    .woocommerce-MyAccount-navigation ul li a {
        padding: 10px 16px;
        font-size: 13px;
        border-left: none;
        border-bottom: 3px solid transparent;
    }

    .woocommerce-MyAccount-navigation ul li a:hover {
        border-left-color: transparent;
        border-bottom-color: var(--saffron);
    }

    .woocommerce-MyAccount-navigation ul li.is-active a {
        border-left-color: transparent;
        border-bottom-color: var(--deep-indigo);
    }

    /* Cart totals full width */
    .woocommerce .cart_totals {
        float: none;
        width: 100%;
    }
}

@media screen and (max-width: 768px) {

    /* Result count & ordering stack */
    .woocommerce .woocommerce-result-count,
    .woocommerce .woocommerce-ordering {
        float: none;
        text-align: center;
        margin-bottom: 16px;
    }

    .woocommerce .woocommerce-ordering {
        display: block;
    }

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

    /* Cart table: horizontal scroll */
    .woocommerce table.shop_table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Coupon form stack */
    .woocommerce .cart .coupon {
        float: none;
        flex-direction: column;
        width: 100%;
        margin-bottom: 12px;
    }

    .woocommerce .cart .coupon .input-text {
        min-width: 0;
        width: 100%;
    }

    .woocommerce .cart .coupon .button {
        width: 100%;
    }

    .woocommerce table.shop_table td.actions > .button {
        float: none;
        width: 100%;
        margin-top: 12px;
    }

    /* Account login/register stack */
    .woocommerce-account .u-columns {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    /* Tabs go horizontal scroll */
    .woocommerce div.product .woocommerce-tabs ul.tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        flex-wrap: nowrap;
    }

    .woocommerce div.product .woocommerce-tabs ul.tabs li a {
        white-space: nowrap;
        padding: 10px 16px;
        font-size: 13px;
    }
}

@media screen and (max-width: 480px) {

    /* Shop grid: single column on small screens */
    .woocommerce ul.products {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .woocommerce-products-header {
        padding: 32px 0 24px;
    }

    /* Pagination compact */
    .woocommerce nav.woocommerce-pagination ul li a,
    .woocommerce nav.woocommerce-pagination ul li span {
        width: 36px;
        height: 36px;
        font-size: 13px;
    }

    /* Single product adjustments */
    .woocommerce div.product div.images .flex-control-thumbs li {
        width: 56px;
        height: 56px;
    }

    .woocommerce div.product form.cart {
        flex-wrap: wrap;
    }

    .woocommerce div.product form.cart .quantity {
        margin-bottom: 12px;
    }

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

    /* Cart & checkout buttons full width */
    .woocommerce .button,
    .woocommerce a.button,
    .woocommerce button.button,
    .woocommerce input.button {
        width: 100%;
        text-align: center;
    }
}

/* ==========================================================================
   19. LOADING / BLOCKUI OVERLAY
   ========================================================================== */

.woocommerce .blockUI.blockOverlay {
    background: var(--ivory) !important;
    opacity: 0.7 !important;
}

.woocommerce .loader::before,
.woocommerce .blockUI.blockOverlay::before {
    border-color: var(--jali);
    border-top-color: var(--saffron);
}

/* ==========================================================================
   20. MISC & UTILITY
   ========================================================================== */

/* Required asterisk */
.woocommerce .required {
    color: var(--rich-maroon);
    text-decoration: none;
    border: none;
}

/* Return to shop link */
.woocommerce .woocommerce-Button--next,
.woocommerce .woocommerce-Button--previous {
    font-size: 13px;
}

/* Order received / Thank You page */
.woocommerce-order-received .woocommerce-order h2 {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 500;
    color: var(--deep-indigo);
    margin: 32px 0 16px;
}

.woocommerce-order-received .woocommerce-order .woocommerce-order-overview {
    list-style: none;
    padding: 24px;
    margin: 0 0 24px;
    background: var(--warm-cream);
    border-radius: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}

.woocommerce-order-received .woocommerce-order .woocommerce-order-overview li {
    font-size: 13px;
    color: var(--clay);
}

.woocommerce-order-received .woocommerce-order .woocommerce-order-overview li strong {
    display: block;
    font-size: 15px;
    color: var(--deep-indigo);
    margin-top: 2px;
}

/* Coupon form on cart/checkout */
.woocommerce-cart .woocommerce-message .showcoupon,
.woocommerce-checkout .woocommerce-info .showcoupon {
    color: var(--saffron);
    font-weight: 500;
}

/* Checkbox / radio base overrides */
.woocommerce form .form-row input[type="checkbox"],
.woocommerce form .form-row input[type="radio"] {
    accent-color: var(--saffron);
    width: 16px;
    height: 16px;
    cursor: pointer;
}

/* Password strength meter */
.woocommerce-password-strength {
    font-family: var(--font-body);
    font-size: 12px;
    padding: 8px 12px;
    border-radius: 4px;
    margin-top: 8px;
}

.woocommerce-password-strength.strong {
    background: rgba(14, 107, 94, 0.1);
    color: var(--peacock);
}

.woocommerce-password-strength.good {
    background: rgba(226, 168, 54, 0.1);
    color: var(--old-gold);
}

.woocommerce-password-strength.bad,
.woocommerce-password-strength.short {
    background: rgba(122, 31, 61, 0.1);
    color: var(--rich-maroon);
}

/* Print styles — keep things clean */
@media print {
    .woocommerce-MyAccount-navigation,
    .woocommerce-breadcrumb {
        display: none;
    }

    .woocommerce-account .woocommerce {
        display: block;
    }
}
