/**
 * NWC Custom WooCommerce Shop Styles - Simplified
 */

/* Typography — Open Sans via theme token (matches style.css + Elementor) */
body.woocommerce,
body.woocommerce-page {
    font-family: var(--font-primary);
}

body.woocommerce input,
body.woocommerce textarea,
body.woocommerce select,
body.woocommerce button,
body.woocommerce .button,
body.woocommerce a.button,
body.woocommerce-page input,
body.woocommerce-page textarea,
body.woocommerce-page select,
body.woocommerce-page button,
body.woocommerce-page .button,
body.woocommerce-page a.button {
    font-family: var(--font-primary);
}

/* ===== SHOP WRAPPER ===== */
.nwc-shop-wrapper {
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
}

/* ===== SHOP HEADER ===== */
.woocommerce-products-header {
    text-align: center;
    margin-bottom: 40px;
    padding: 30px 20px;
    background: var(--color-green-dark);
    border-radius: 10px;
    color: var(--color-white);
}

.woocommerce-products-header__title {
    font-family: var(--font-primary);
    font-size: 42px;
    font-weight: 600;
    line-height: 1.2em;
    margin: 0 0 15px 0;
    color: var(--color-white) !important;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}

/* ===== CART SUMMARY BAR ===== */
.nwc-cart-summary-bar {
    background: var(--color-green-dark);
    color: var(--color-white);
    padding: 20px;
    margin-top: 40px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.nwc-cart-summary-content {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
}

.nwc-cart-info {
    display: flex;
    align-items: center;
    gap: 15px;
    font-size: 1.1em;
    font-weight: 600;
}

.nwc-cart-info .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
}

.nwc-cart-total {
    color: var(--color-orange);
    font-size: 1.2em;
}

.nwc-cart-actions {
    display: flex;
    gap: 10px;
}

.nwc-view-cart-btn,
.nwc-checkout-btn {
    background-color: var(--color-orange) !important;
    color: var(--color-white) !important;
    padding: 10px 25px !important;
    border-radius: 5px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
    border: none !important;
}

.nwc-view-cart-btn:hover {
    background-color: var(--color-orange-hover) !important;
}

.nwc-checkout-btn {
    background-color: var(--color-orange) !important;
    color: var(--color-white) !important;
}

.nwc-checkout-btn:hover {
    background-color: var(--color-orange-hover) !important;
}

/* ===== PRODUCT GRID - SIMPLIFIED ===== */
.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    justify-items: start !important;
    align-items: start !important;
}

.woocommerce ul.products li.product {
    background: var(--color-white) !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08) !important;
    transition: all 0.3s ease !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    float: none !important;
}

.woocommerce ul.products li.product:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.15) !important;
}

/* ===== PRODUCT IMAGE - SQUARE ===== */
.woocommerce ul.products li.product a img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ===== PRODUCT TITLE ===== */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 1.1em !important;
    padding: 15px 15px 10px !important;
    margin: 0 !important;
    color: var(--color-text) !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
}

/* ===== PRICE ===== */
.woocommerce ul.products li.product .price {
    font-size: 1.3em !important;
    font-weight: 700 !important;
    padding: 0 15px 15px !important;
    margin: 0 !important;
    color: var(--color-green-dark) !important;
}

/* ===== ADD TO CART BUTTON ===== */
.woocommerce ul.products li.product .button {
    background-color: var(--color-green-light) !important;
    color: var(--color-white) !important;
    padding: 12px 20px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    text-align: center !important;
    border: none !important;
    width: calc(100% - 30px) !important;
    margin: 0 15px 15px !important;
    display: block !important;
    text-decoration: none !important;
}

.woocommerce ul.products li.product .button:hover {
    background-color: var(--color-green-dark) !important;
}

.woocommerce ul.products li.product .added_to_cart {
    background-color: var(--color-green-dark) !important;
    color: var(--color-white) !important;
    padding: 10px 20px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    text-align: center !important;
    display: block !important;
    width: calc(100% - 30px) !important;
    margin: 10px 15px 15px !important;
    text-decoration: none !important;
}

/* ===== SALE BADGE ===== */
.woocommerce span.onsale {
    background-color: var(--color-orange) !important;
    color: var(--color-white) !important;
    padding: 8px 12px !important;
    border-radius: 5px !important;
    font-weight: 700 !important;
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    z-index: 10 !important;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 768px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 20px !important;
    }
    
    .nwc-cart-summary-content {
        flex-direction: column;
        text-align: center;
    }
    
    .nwc-cart-actions {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .woocommerce ul.products {
        grid-template-columns: 1fr !important;
    }
    
    .nwc-cart-actions {
        flex-direction: column;
        width: 100%;
    }
}

/* ===== RESULT COUNT & ORDERING ===== */
.woocommerce-result-count {
    color: var(--color-text);
    font-size: 0.95em;
}

.woocommerce-ordering select {
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: 5px;
    background: var(--color-white);
    color: var(--color-text);
}

/* ============================================================
   SINGLE PRODUCT PAGE (matches shop wrapper and colour scheme)
   ============================================================ */

.nwc-single-product-wrapper {
    /* Uses same .nwc-shop-wrapper rules: max-width, margin, padding */
}

/* Single product layout: image + summary side by side */
.single-product .nwc-single-product-wrapper .woocommerce-product-details__short-description,
.single-product .nwc-single-product-wrapper .summary .woocommerce-product-details__short-description {
    margin-bottom: 1em;
    color: var(--color-text);
    line-height: 1.6;
}

.single-product .nwc-single-product-wrapper .summary.entry-summary {
    padding: 0;
}

.single-product .nwc-single-product-wrapper .product .woocommerce-product-gallery {
    margin-bottom: 1.5em;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
}

.single-product .nwc-single-product-wrapper .product .summary .product_title {
    font-size: 1.75em;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 0.5em 0;
    line-height: 1.3;
}

.single-product .nwc-single-product-wrapper .product .summary .price {
    font-size: 1.5em !important;
    font-weight: 700 !important;
    color: var(--color-green-dark) !important;
    margin: 0 0 1em 0 !important;
}

/* Single product Add to Cart button - match shop green */
.single-product .nwc-single-product-wrapper .product .summary .single_add_to_cart_button {
    background-color: var(--color-green-light) !important;
    color: var(--color-white) !important;
    padding: 12px 24px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    border: none !important;
    transition: all 0.3s ease;
}

.single-product .nwc-single-product-wrapper .product .summary .single_add_to_cart_button:hover {
    background-color: var(--color-green-dark) !important;
}

/* Sale badge on single product */
.single-product .nwc-single-product-wrapper .product span.onsale {
    background-color: var(--color-orange) !important;
    color: var(--color-white) !important;
    padding: 8px 12px !important;
    border-radius: 5px !important;
    font-weight: 700 !important;
}

/* Product meta (SKU, categories) */
.single-product .nwc-single-product-wrapper .product .summary .product_meta {
    padding-top: 1em;
    margin-top: 1em;
    border-top: 1px solid var(--color-border);
    font-size: 0.9em;
    color: var(--color-text);
}

/* Tabs (Description, Additional info, Reviews) */
.single-product .nwc-single-product-wrapper .woocommerce-tabs {
    margin-top: 2.5em;
    padding-top: 1.5em;
    border-top: 1px solid var(--color-border);
}

.single-product .nwc-single-product-wrapper .woocommerce-tabs ul.tabs {
    list-style: none;
    margin: 0 0 1em 0;
    padding: 0;
    border-bottom: 2px solid var(--color-border);
    display: flex;
    flex-wrap: wrap;
    gap: 0;
}

.single-product .nwc-single-product-wrapper .woocommerce-tabs ul.tabs li {
    margin: 0;
    padding: 0;
}

.single-product .nwc-single-product-wrapper .woocommerce-tabs ul.tabs li a {
    display: inline-block;
    padding: 12px 20px;
    color: var(--color-text);
    text-decoration: none;
    font-weight: 600;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: color 0.2s, border-color 0.2s;
}

.single-product .nwc-single-product-wrapper .woocommerce-tabs ul.tabs li.active a,
.single-product .nwc-single-product-wrapper .woocommerce-tabs ul.tabs li a:hover {
    color: var(--color-green-dark);
    border-bottom-color: var(--color-green-dark);
}

.single-product .nwc-single-product-wrapper .woocommerce-Tabs-panel {
    padding: 1em 0;
    color: var(--color-text);
    line-height: 1.6;
}

/* Related products / Upsells - reuse shop grid styling */
.single-product .nwc-single-product-wrapper .related.products,
.single-product .nwc-single-product-wrapper .upsells.products {
    margin-top: 2.5em;
    padding-top: 1.5em;
    border-top: 1px solid var(--color-border);
}

.single-product .nwc-single-product-wrapper .related.products h2,
.single-product .nwc-single-product-wrapper .upsells.products h2 {
    font-size: 1.5em;
    font-weight: 600;
    color: var(--color-green-dark);
    margin: 0 0 1em 0;
}

.single-product .nwc-single-product-wrapper .related ul.products,
.single-product .nwc-single-product-wrapper .upsells ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px !important;
}

@media (max-width: 1024px) {
    .single-product .nwc-shop-wrapper .related ul.products,
    .single-product .nwc-single-product-wrapper .related ul.products,
    .single-product .nwc-shop-wrapper .upsells ul.products,
    .single-product .nwc-single-product-wrapper .upsells ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 480px) {
    .single-product .nwc-shop-wrapper .related ul.products,
    .single-product .nwc-single-product-wrapper .related ul.products,
    .single-product .nwc-shop-wrapper .upsells ul.products,
    .single-product .nwc-single-product-wrapper .upsells ul.products {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================================
   CART PAGE – same wrapper width and colour scheme as shop
   ============================================================ */

body.woocommerce-cart .woocommerce {
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
}

body.woocommerce-cart .woocommerce-cart-form .shop_table {
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
    border: 1px solid var(--color-border);
}

body.woocommerce-cart .woocommerce-cart-form thead th {
    background: var(--color-green-dark);
    color: var(--color-white);
    padding: 12px 15px;
    font-weight: 600;
    border: none;
}

body.woocommerce-cart .cart_totals {
    background: var(--color-background);
    border-radius: 10px;
    padding: 20px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
    border: 1px solid var(--color-border);
}

body.woocommerce-cart .cart_totals h2 {
    color: var(--color-green-dark);
    font-size: 1.25em;
    font-weight: 600;
    margin: 0 0 1em 0;
}

body.woocommerce-cart .woocommerce-checkout-review-order-table .order-total .amount {
    color: var(--color-green-dark);
    font-weight: 700;
}

body.woocommerce-cart .checkout-button {
    background-color: var(--color-orange) !important;
    color: var(--color-white) !important;
    padding: 12px 24px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    border: none !important;
    text-decoration: none !important;
    display: inline-block;
    transition: all 0.3s ease;
}

body.woocommerce-cart .checkout-button:hover {
    background-color: var(--color-orange-hover) !important;
    color: var(--color-white) !important;
}

body.woocommerce-cart .cart-empty {
    text-align: center;
    padding: 2em 0;
}

body.woocommerce-cart .return-to-shop .button {
    background-color: var(--color-green-light) !important;
    color: var(--color-white) !important;
    padding: 10px 20px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    border: none !important;
}

body.woocommerce-cart .return-to-shop .button:hover {
    background-color: var(--color-green-dark) !important;
}

body.woocommerce-cart .button[name="update_cart"] {
    background-color: var(--color-background) !important;
    color: var(--color-text) !important;
    padding: 10px 20px !important;
    border-radius: 5px !important;
    border: 1px solid var(--color-border) !important;
}

/* ============================================================
   CHECKOUT PAGE – same wrapper and colours
   ============================================================ */

body.woocommerce-checkout .woocommerce {
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
}

body.woocommerce-checkout .woocommerce-billing-fields h3,
body.woocommerce-checkout .woocommerce-shipping-fields h3,
body.woocommerce-checkout #order_review_heading {
    color: var(--color-green-dark);
    font-size: 1.25em;
    font-weight: 600;
    margin: 0 0 0.75em 0;
}

body.woocommerce-checkout .form-row input.input-text,
body.woocommerce-checkout .form-row select {
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: 5px;
    background: var(--color-white);
}

/* Terms and conditions checkbox – keep checkbox and label text on one line */
body.woocommerce-checkout .woocommerce-form__label-for-checkbox.checkbox {
    display: flex !important;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.5em;
}

body.woocommerce-checkout .woocommerce-form__label-for-checkbox.checkbox input {
    flex-shrink: 0;
    width: auto;
    margin: 0;
}

body.woocommerce-checkout #place_order {
    background-color: var(--color-orange) !important;
    color: var(--color-white) !important;
    padding: 14px 28px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    border: none !important;
    width: 100%;
    transition: all 0.3s ease;
}

body.woocommerce-checkout #place_order:hover {
    background-color: var(--color-orange-hover) !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table {
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
    border: 1px solid var(--color-border);
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table thead th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total th {
    background: var(--color-green-dark);
    color: var(--color-white);
    padding: 12px 15px;
    font-weight: 600;
    border: none;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .amount {
    color: var(--color-orange);
    font-weight: 700;
}

/* ============================================================
   MY ACCOUNT (WooCommerce /my-account/ only)
   Scoped to body.woocommerce-account so member dashboard is NOT
   affected (dashboard uses nwc-member-dashboard-page, no .woocommerce-account).
   ============================================================ */

body.woocommerce-account .woocommerce {
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
}

body.woocommerce-account .woocommerce-MyAccount-navigation {
    margin-bottom: 2em;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    border-bottom: 2px solid var(--color-border);
    display: flex;
    flex-wrap: wrap;
    gap: 0;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    margin: 0;
    padding: 0;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: inline-block;
    padding: 12px 20px;
    color: var(--color-text);
    text-decoration: none;
    font-weight: 600;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: color 0.2s, border-color 0.2s;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
    color: var(--color-green-dark);
    border-bottom-color: var(--color-green-dark);
}

body.woocommerce-account .woocommerce-MyAccount-content h2 {
    color: var(--color-green-dark);
    font-size: 1.25em;
    font-weight: 600;
    margin: 0 0 0.75em 0;
}

body.woocommerce-account .woocommerce-orders-table {
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
    border: 1px solid var(--color-border);
}

body.woocommerce-account .woocommerce-orders-table thead th {
    background: var(--color-green-dark);
    color: var(--color-white);
    padding: 12px 15px;
    font-weight: 600;
    border: none;
}

body.woocommerce-account .woocommerce-MyAccount-content .button {
    background-color: var(--color-green-light) !important;
    color: var(--color-white) !important;
    padding: 10px 20px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    border: none !important;
}

body.woocommerce-account .woocommerce-MyAccount-content .button:hover {
    background-color: var(--color-green-dark) !important;
}

body.woocommerce-account .woocommerce-address-fields .button {
    background-color: var(--color-green-light) !important;
    color: var(--color-white) !important;
}

body.woocommerce-account .woocommerce-address-fields .button:hover {
    background-color: var(--color-green-dark) !important;
}
