/* =====================================================
   LIMITLESS ENERGY POWDER — WooCommerce Styles
   Covers: Product Page, Cart, Checkout, Order, Account
   v2
   ===================================================== */

/* ── Shared WC page wrapper ─────────────────────────── */
.woocommerce-page .wc-page-container,
.woocommerce .woocommerce-page-container {
    padding: 3rem 0 5rem;
}

.wc-page-banner {
    background: linear-gradient(135deg, var(--color-primary-xlight) 0%, #ffffff 100%);
    padding: 3rem 0 2.5rem;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 3rem;
}
.wc-page-banner .woocommerce-breadcrumb {
    font-size: .825rem;
    color: var(--color-muted);
    margin-bottom: .75rem;
}
.wc-page-banner .woocommerce-breadcrumb a { color: var(--color-primary); }
.wc-page-banner h1 {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 800;
    color: var(--color-black);
}

/* ── Notices ─────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info,
.woocommerce-notice {
    padding: 1rem 1.5rem;
    border-radius: 10px;
    margin-bottom: 1.5rem;
    font-weight: 500;
    font-size: .9rem;
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}
.woocommerce-message { background: #f0f0d0; border-left: 4px solid var(--color-primary-dark); color: #5a5a18; }
.woocommerce-error   { background: #fee2e2; border-left: 4px solid #ef4444; color: #7f1d1d; }
.woocommerce-info    { background: #dbeafe; border-left: 4px solid #3b82f6; color: #1e3a8a; }

.woocommerce-message a.button,
.woocommerce-message .button {
    margin-left: auto;
    background: var(--color-primary) !important;
    color: var(--color-black) !important;
    padding: .5rem 1.25rem !important;
    border-radius: 50px !important;
    font-size: .8rem !important;
    font-weight: 700 !important;
}

/* ── Global WC Buttons ───────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button.alt,
.woocommerce button.button.alt {
    background: var(--color-primary) !important;
    color: var(--color-black) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: .8rem 2rem !important;
    font-family: var(--font-heading) !important;
    font-size: .95rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all .25s !important;
    box-shadow: 0 4px 16px rgba(221,220,140,.4) !important;
    letter-spacing: .01em !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background: #c8c760 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(221,220,140,.5) !important;
}

/* ── Global WC Inputs ────────────────────────────────── */
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="number"],
.woocommerce input[type="password"],
.woocommerce textarea,
.woocommerce select {
    width: 100%;
    padding: .75rem 1rem !important;
    border: 2px solid var(--color-border) !important;
    border-radius: 8px !important;
    font-size: .95rem !important;
    font-family: var(--font-body) !important;
    color: var(--color-text) !important;
    background: #fff !important;
    transition: border-color .2s !important;
    outline: none !important;
}
.woocommerce input:focus,
.woocommerce textarea:focus,
.woocommerce select:focus {
    border-color: var(--color-primary-dark) !important;
    box-shadow: 0 0 0 3px rgba(221,220,140,.25) !important;
}

/* ═══════════════════════════════════════════════════════
   PRODUCT DETAIL PAGE (single-product)
   ═══════════════════════════════════════════════════════ */
.single-product-page {
    background: #fff;
}
.sp-breadcrumb {
    background: var(--color-light-bg);
    padding: 1rem 0;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 0;
}
.sp-breadcrumb .woocommerce-breadcrumb {
    font-size: .8rem;
    color: var(--color-muted);
}
.sp-breadcrumb .woocommerce-breadcrumb a {
    color: var(--color-primary);
    font-weight: 500;
}
.sp-main { padding: 3rem 0; }

/* Product summary WC hooks */
.woocommerce div.product .product_title {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 800;
    margin-bottom: .5rem;
    color: var(--color-black);
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
    font-size: 2rem !important;
    font-weight: 800 !important;
    color: var(--color-primary-dark) !important;
    margin: 1rem 0 !important;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
    color: var(--color-muted) !important;
    font-size: 1.25rem !important;
    opacity: .7;
}
.woocommerce div.product .woocommerce-product-rating {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .75rem;
}
.woocommerce .star-rating { color: #f59e0b; font-size: 1rem; }
.woocommerce .woocommerce-review-link { font-size: .825rem; color: var(--color-muted); }

/* Description / Tabs */
.woocommerce div.product .woocommerce-tabs {
    margin-top: 3rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--color-border);
    padding: 0;
    margin-bottom: 0;
    list-style: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: .875rem 1.5rem;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: .95rem;
    color: var(--color-muted);
    text-decoration: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: all .2s;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}
.woocommerce div.product .woocommerce-tabs .panel {
    padding: 2rem 0;
    border: none;
    background: transparent;
}

/* Add to cart form on single product page */
.woocommerce div.product form.cart {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin: 1.25rem 0;
}
.woocommerce div.product form.cart .qty {
    width: 80px !important;
    height: 52px !important;
    text-align: center !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    border: 2px solid var(--color-border) !important;
    border-radius: 10px !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button {
    flex: 1;
    min-width: 200px;
    padding: 1rem 2rem !important;
    font-size: 1rem !important;
    font-weight: 800 !important;
    border-radius: 50px !important;
    background: var(--color-primary) !important;
    color: var(--color-black) !important;
    box-shadow: 0 4px 20px rgba(221,220,140,.45) !important;
    border: none !important;
    cursor: pointer !important;
    transition: all .25s !important;
    letter-spacing: .02em !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
    background: #c8c760 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 28px rgba(221,220,140,.55) !important;
}

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
    color: var(--color-muted);
    line-height: 1.7;
    font-size: .95rem;
    border-left: 3px solid var(--color-primary);
    padding-left: 1rem;
    margin: .5rem 0;
}
.woocommerce div.product .woocommerce-product-details__short-description p { margin-bottom: .5rem; }

/* Product meta (SKU, categories) */
.woocommerce div.product .product_meta {
    font-size: .825rem;
    color: var(--color-muted);
    padding-top: .75rem;
    border-top: 1px solid var(--color-border);
}
.woocommerce div.product .product_meta span { display: inline-block; margin-right: 1rem; }
.woocommerce div.product .product_meta a { color: var(--color-primary); }

/* Related products — hidden for single-product site */
.related.products { display: none; }
.up-sells.products { display: none; }

/* Product tabs content */
.product-tabs-section {
    padding: 4rem 0;
    background: var(--color-light-bg);
}
.product-tabs-section .woocommerce-tabs {
    background: #fff;
    border-radius: 16px;
    padding: 0 2rem;
    box-shadow: var(--shadow-sm);
}
.product-tabs-section .woocommerce-tabs ul.tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--color-border);
    padding: 0;
    margin-bottom: 0;
    list-style: none;
}
.product-tabs-section .woocommerce-tabs ul.tabs li {
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    margin: 0;
}
.product-tabs-section .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: .875rem 1.5rem;
    font-weight: 600;
    font-size: .95rem;
    color: var(--color-muted);
    text-decoration: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: all .2s;
}
.product-tabs-section .woocommerce-tabs ul.tabs li.active a,
.product-tabs-section .woocommerce-tabs ul.tabs li a:hover {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}
.product-tabs-section .woocommerce-tabs .panel {
    padding: 2rem 0;
    border: none;
    background: transparent;
}

/* ═══════════════════════════════════════════════════════
   CART PAGE
   ═══════════════════════════════════════════════════════ */
.woocommerce-cart .wc-page-container {
    max-width: 1100px;
    margin: 0 auto;
}

/* Cart Table — excludes the checkout order review table */
.woocommerce-cart table.cart,
.woocommerce table.shop_table:not(.woocommerce-checkout-review-order-table) {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border) !important;
    margin-bottom: 2rem !important;
}
.woocommerce-cart table.cart thead th,
.woocommerce table.shop_table:not(.woocommerce-checkout-review-order-table) thead th {
    background: var(--color-light-bg) !important;
    padding: 1rem 1.25rem !important;
    font-family: var(--font-heading) !important;
    font-size: .8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .07em !important;
    color: var(--color-muted) !important;
    border-bottom: 1px solid var(--color-border) !important;
    text-align: left !important;
}
.woocommerce-cart table.cart td,
.woocommerce table.shop_table:not(.woocommerce-checkout-review-order-table) td {
    padding: 1.25rem 1.25rem !important;
    border-bottom: 1px solid var(--color-border) !important;
    vertical-align: middle !important;
    color: var(--color-text) !important;
}
.woocommerce-cart table.cart tr:last-child td { border-bottom: none !important; }

/* Product image in cart */
.woocommerce-cart .product-thumbnail img {
    width: 80px !important;
    height: 80px !important;
    object-fit: cover;
    border-radius: 10px;
    border: 2px solid var(--color-border);
}
.woocommerce-cart .product-name a {
    font-weight: 600;
    font-size: 1rem;
    color: var(--color-black);
    text-decoration: none;
}
.woocommerce-cart .product-name a:hover { color: var(--color-primary); }

/* Quantity in cart */
.woocommerce-cart .quantity input {
    width: 70px !important;
    height: 44px !important;
    text-align: center !important;
    border: 2px solid var(--color-border) !important;
    border-radius: 8px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
}
.woocommerce-cart .product-price,
.woocommerce-cart .product-subtotal {
    font-weight: 700 !important;
    color: var(--color-primary-dark) !important;
}

/* Remove button */
.woocommerce-cart .product-remove a {
    width: 28px !important;
    height: 28px !important;
    background: #fee2e2 !important;
    color: #dc2626 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 1rem !important;
    text-decoration: none !important;
    transition: all .2s !important;
}
.woocommerce-cart .product-remove a:hover {
    background: #dc2626 !important;
    color: white !important;
}

/* Cart totals */
.woocommerce-cart .cart-collaterals {
    display: block;
    margin-top: 2rem;
}
.woocommerce-cart .cart_totals {
    width: 100%;
    max-width: 420px;
    margin-left: auto;
    background: #fff;
    border-radius: 16px;
    padding: 2rem;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-border);
    position: sticky;
    top: 100px;
}
.woocommerce-cart .cart_totals h2 {
    font-size: 1.25rem;
    font-weight: 800;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid var(--color-primary-light);
}
.woocommerce-cart .cart_totals table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.5rem;
}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
    padding: .75rem 0 !important;
    border-bottom: 1px solid var(--color-border) !important;
    font-size: .95rem !important;
}
.woocommerce-cart .cart_totals table th { font-weight: 600; color: var(--color-muted); }
.woocommerce-cart .cart_totals table td { font-weight: 700; color: var(--color-black); text-align: right; }
.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
    font-size: 1.1rem !important;
    color: var(--color-primary-dark) !important;
    border-bottom: none !important;
    padding-top: 1rem !important;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
    width: 100% !important;
    padding: 1rem !important;
    font-size: 1.05rem !important;
    display: block !important;
    text-align: center !important;
}

/* Coupon area */
.woocommerce-cart .coupon {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}
.woocommerce-cart .coupon input#coupon_code {
    flex: 1;
    min-width: 160px;
}

/* Cart actions */
.woocommerce-cart .actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 1rem 0 0;
}

/* ═══════════════════════════════════════════════════════
   CHECKOUT PAGE
   Our form-checkout.php wraps billing/shipping in .co-card divs.
   These styles MUST NOT add extra borders/backgrounds — co-card
   already provides the card look.
   ═══════════════════════════════════════════════════════ */

/* Reset floats from WC default template */
.woocommerce-checkout #customer_details,
.woocommerce-checkout .woocommerce-checkout-review-order {
    float: none !important;
    width: 100% !important;
}

/* WC section headings — plain text, no card-header background */
.woocommerce-checkout .woocommerce-billing-fields > h3,
.woocommerce-checkout .woocommerce-shipping-fields > h3,
.woocommerce-checkout .woocommerce-additional-fields > h3,
.woocommerce-checkout h3#order_review_heading {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--color-black);
    margin-bottom: 1.25rem;
    padding-bottom: .75rem;
    border-bottom: 2px solid var(--color-primary-light);
    background: none;
    border-left: none;
    border-right: none;
    border-top: none;
    border-radius: 0;
    padding-left: 0;
    padding-right: 0;
    padding-top: 0;
}

/* WC billing/shipping wrappers — NO extra border (co-card provides it) */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout .woocommerce-additional-fields,
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .woocommerce-additional-fields__field-wrapper {
    background: transparent;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin-bottom: 0 !important;
}

/* 2-col form grid for billing / shipping fields */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 0 1rem;
}
@media(max-width:600px) {
    .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
    .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
        grid-template-columns: 1fr !important;
    }
}

/* Form rows */
.woocommerce-checkout .form-row {
    margin-bottom: 1rem !important;
    float: none !important;
    width: 100% !important;
}
.woocommerce-checkout .form-row-wide { grid-column: 1 / -1; }
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last  { width: 100% !important; }

.woocommerce-checkout .form-row label {
    display: block;
    font-size: .85rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: .3rem;
}
.woocommerce-checkout .form-row label .required { color: var(--color-primary); margin-left: 2px; }
.woocommerce-checkout .form-row .input-text,
.woocommerce-checkout .form-row select {
    width: 100%;
}
.woocommerce-checkout .form-row.woocommerce-invalid .input-text { border-color: #ef4444 !important; }
.woocommerce-checkout .form-row.woocommerce-validated .input-text { border-color: var(--color-primary) !important; }

/* "Ship to a different address" toggle */
.woocommerce-checkout .woocommerce-shipping-fields h3 label {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 800;
    border: none;
    padding: 0;
    background: none;
}

/* ── "Your Order" column ─────────────────────────────
   co-section-head in the template provides the heading;
   WC's own #order_review_heading is hidden.              */
h3#order_review_heading { display: none !important; }

#order_review {
    background: transparent;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
}

/* ── Review table ───────────────────────────────────── */
.woocommerce-checkout-review-order-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 0;
    font-size: .875rem;
}

/* Column headers */
.woocommerce-checkout-review-order-table thead th {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--color-muted);
    padding: 0 0 .4rem !important;
    border-bottom: 2px solid var(--color-border) !important;
}
.woocommerce-checkout-review-order-table thead .product-total { text-align: right; }

/* Product body rows */
.woocommerce-checkout-review-order-table tbody td {
    padding: .6rem 0 !important;
    border-bottom: 1px solid var(--color-border) !important;
    vertical-align: top;
}
.woocommerce-checkout-review-order-table .product-name {
    font-weight: 600;
    color: var(--color-black);
    line-height: 1.45;
    padding-right: 1rem !important;
}
.woocommerce-checkout-review-order-table .product-total {
    text-align: right;
    font-weight: 700;
    white-space: nowrap;
    color: var(--color-black);
}

/* Bundle/variation meta — "Package: 3 Bottles – 60-day supply" */
.woocommerce-checkout-review-order-table .wc-item-meta,
.woocommerce-checkout-review-order-table .variation {
    list-style: none;
    padding: 0;
    margin: 4px 0 0;
}
.woocommerce-checkout-review-order-table .wc-item-meta li,
.woocommerce-checkout-review-order-table .wc-item-meta p,
.woocommerce-checkout-review-order-table .variation dt,
.woocommerce-checkout-review-order-table .variation dd {
    font-size: .77rem;
    color: var(--color-muted);
    margin: 0;
    padding: 0;
    display: inline;
}
.woocommerce-checkout-review-order-table .wc-item-meta .wc-item-meta-label { font-weight: 600; color: var(--color-text); }

/* Tfoot — coupon, shipping, tax, total */
.woocommerce-checkout-review-order-table tfoot th,
.woocommerce-checkout-review-order-table tfoot td {
    padding: .35rem 0 !important;
    border-bottom: none !important;
    font-size: .85rem;
    vertical-align: top !important;
}
.woocommerce-checkout-review-order-table tfoot th {
    color: var(--color-muted);
    font-weight: 500;
    white-space: nowrap;
    padding-top: .5rem !important;
}
.woocommerce-checkout-review-order-table tfoot td {
    text-align: right;
    font-weight: 600;
    color: var(--color-black);
}
/* Shipping row td — override text-align:right so form fields lay out normally */
.woocommerce-checkout-review-order-table .shipping td {
    text-align: left !important;
}

/* ── Shipping method radio list ─────────────────────── */
#order_review #shipping_method {
    list-style: none;
    margin: 0 0 .5rem;
    padding: 0;
}
#order_review #shipping_method li {
    display: flex;
    align-items: center;
    gap: .4rem;
    padding: .2rem 0;
    font-size: .85rem;
    font-weight: 500;
    color: var(--color-text);
}
#order_review #shipping_method li input[type="radio"] {
    accent-color: var(--color-primary-dark);
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}
#order_review #shipping_method li label { cursor: pointer; margin: 0; font-weight: 500; }

/* "Shipping to WY. Change address" line */
.woocommerce-shipping-destination {
    font-size: .8rem;
    color: var(--color-muted);
    margin: .35rem 0 .5rem;
}
.woocommerce-shipping-destination a.shipping-calculator-button {
    color: var(--color-primary);
    font-weight: 600;
    text-decoration: none;
    margin-left: .3rem;
}

/* ── Shipping calculator form ───────────────────────── */
.woocommerce-shipping-calculator { margin-top: .4rem; }
.shipping-calculator-form { padding-top: .5rem; }
.shipping-calculator-form .form-row {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    margin-bottom: .5rem;
}
.shipping-calculator-form .form-row label {
    font-size: .78rem;
    font-weight: 600;
    color: var(--color-muted);
    text-align: left !important;
}
.shipping-calculator-form .form-row select,
.shipping-calculator-form .form-row input[type="text"],
.shipping-calculator-form .form-row input[type="number"] {
    width: 100%;
    padding: .45rem .6rem;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    font-size: .85rem;
    background: #fff;
    color: var(--color-text);
    box-sizing: border-box;
}
.shipping-calculator-form button[name="calc_shipping"] {
    display: inline-block;
    padding: .5rem 1.25rem;
    background: var(--color-primary);
    color: var(--color-black);
    border: none;
    border-radius: 8px;
    font-size: .85rem;
    font-weight: 700;
    cursor: pointer;
    margin-top: .25rem;
}
.shipping-calculator-form button[name="calc_shipping"]:hover {
    background: var(--color-primary-dark);
}

/* Order total — stands out */
.woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout-review-order-table .order-total td {
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    color: var(--color-primary-dark) !important;
    border-top: 2px solid var(--color-border) !important;
    border-bottom: none !important;
    padding-top: .65rem !important;
}

/* ── Payment section wrapper ────────────────────────── */
#payment {
    background: #f9f9f2;
    border-radius: 10px;
    padding: .875rem 1.1rem 1rem;
    border: 1px solid var(--color-border);
    margin-top: 1rem;
}

/* Section label */
#payment > h3 {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--color-muted);
    margin: 0 0 .75rem;
}

/* ── Payment method list ────────────────────────────── */
#payment ul.payment_methods {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Each method is a BLOCK so the description box sits below the label */
#payment ul.payment_methods li {
    display: block;
    padding: .4rem 0;
    border-bottom: 1px solid var(--color-border);
}
#payment ul.payment_methods li:last-child { border-bottom: none; }

/* Radio + label on the same line */
#payment ul.payment_methods li > input[type="radio"] {
    width: 15px;
    height: 15px;
    accent-color: var(--color-primary-dark);
    vertical-align: middle;
    margin-right: .5rem;
    cursor: pointer;
    flex-shrink: 0;
}
/* Hide gateway text, show only the logo image */
#payment ul.payment_methods li > label {
    display: inline;
    font-size: 0;          /* hides the text node */
    font-weight: 600;
    color: transparent;
    cursor: pointer;
    vertical-align: middle;
}
/* Payment logos */
#payment ul.payment_methods li > label img {
    display: inline-block;
    height: 24px;
    vertical-align: middle;
    margin-left: .25rem;
    border-radius: 3px;
    font-size: initial;    /* restore in case img needs font context */
}
/* Fallback: if no logo image, show text at normal size */
#payment ul.payment_methods li > label:not(:has(img)) {
    font-size: .9rem;
    color: var(--color-text);
}

/* Description / instructions box — below the label row */
#payment .payment_box {
    background: #fff;
    padding: .5rem .75rem;
    border-radius: 6px;
    font-size: .8rem;
    color: var(--color-muted);
    line-height: 1.45;
    margin: .3rem 0 .2rem 0rem;
    border: 1px solid var(--color-border);
}
#payment .payment_box p { margin: 0; }
/* Collapse extra spacing inside Stripe's card element wrapper */
#payment .payment_box > *:first-child { margin-top: 0; }
#payment .payment_box > *:last-child  { margin-bottom: 0; }

/* ── Terms & Conditions ─────────────────────────────── */
.woocommerce-terms-and-conditions-wrapper {
    margin: 1rem 0 .75rem;
    padding-top: .875rem;
    border-top: 1px solid var(--color-border);
}

/* Privacy policy notice */
.woocommerce-privacy-policy-text {
    font-size: .78rem;
    color: var(--color-muted);
    line-height: 1.5;
    margin-bottom: .6rem;
}
.woocommerce-privacy-policy-text a {
    color: var(--color-primary-dark);
    text-decoration: underline;
}

/* Scrollable terms text (shown when "Read terms" is clicked) */
.woocommerce-terms-and-conditions {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: .75rem 1rem;
    font-size: .8rem;
    color: var(--color-muted);
    max-height: 140px;
    overflow-y: auto;
    margin-bottom: .75rem;
    line-height: 1.55;
}

/* Checkbox row */
#terms_and_conditions_field {
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    width: 100% !important;
}
#terms_and_conditions_field .woocommerce-form__label-for-checkbox {
    display: flex;
    align-items: flex-start;
    gap: .5rem;
    cursor: pointer;
    font-size: .875rem;
    color: var(--color-text);
    font-weight: 500;
    line-height: 1.45;
}
#terms_and_conditions_field .woocommerce-form__input-checkbox {
    width: 16px;
    height: 16px;
    accent-color: var(--color-primary-dark);
    flex-shrink: 0;
    margin-top: 2px;
    cursor: pointer;
}
#terms_and_conditions_field .woocommerce-terms-and-conditions-checkbox-text a {
    color: var(--color-primary-dark);
    font-weight: 600;
    text-decoration: underline;
}
#terms_and_conditions_field .required { color: #ef4444; margin-left: 2px; }

/* ── Place Order button ─────────────────────────────── */
#payment .place-order { margin-top: .875rem; }
#payment #place_order {
    width: 100% !important;
    padding: 1rem 1.5rem !important;
    font-size: 1rem !important;
    font-weight: 800 !important;
    background: var(--color-primary) !important;
    color: var(--color-black) !important;
    border: none !important;
    border-radius: 50px !important;
    cursor: pointer;
    display: block !important;
    text-align: center;
    letter-spacing: .02em;
    transition: background .2s, transform .2s, box-shadow .2s;
    box-shadow: 0 4px 16px rgba(221,220,140,.45);
    margin-top: 0;
}
#payment #place_order:hover {
    background: var(--color-primary-dark) !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(221,220,140,.55);
}

/* ── Misc ───────────────────────────────────────────── */
.woocommerce-checkout #customer_details { margin-bottom: 2rem; }
.woocommerce-page.woocommerce-checkout .woocommerce { display: block; }

@media (max-width: 900px) {
    .woocommerce-checkout .col2-set { grid-template-columns: 1fr; }
    #order_review { position: static; }
}
@media (max-width: 600px) {
    .woocommerce-cart table.cart thead { display: none; }
    .woocommerce-cart table.cart tr { display: flex; flex-wrap: wrap; padding: 1rem; border-bottom: 1px solid var(--color-border); }
    .woocommerce-cart table.cart td { border: none !important; padding: .25rem .5rem !important; }
    .woocommerce-cart table.cart .product-thumbnail { width: 70px; }
}

/* ═══════════════════════════════════════════════════════
   ORDER RECEIVED (Thank You Page)
   ═══════════════════════════════════════════════════════ */
.woocommerce-order {
    text-align: center;
    padding: 2rem 0;
}
.woocommerce-order .woocommerce-order-received h2,
.woocommerce-order p.woocommerce-notice { display: none; }

/* Big thank you card */
.woocommerce-thankyou-order-received {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--color-primary-dark);
    padding: 2rem;
    background: var(--color-primary-xlight);
    border-radius: 16px;
    border: 1px solid rgba(221,220,140,.35);
    margin-bottom: 2rem;
    text-align: center;
}

/* Order details */
.woocommerce-order-details,
.woocommerce-customer-details {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 2rem;
    margin-bottom: 2rem;
    box-shadow: var(--shadow-sm);
}
.woocommerce-order-details h2,
.woocommerce-customer-details h2 {
    font-size: 1.1rem;
    font-weight: 800;
    margin-bottom: 1.25rem;
    padding-bottom: .75rem;
    border-bottom: 2px solid var(--color-primary-light);
}

/* ═══════════════════════════════════════════════════════
   MY ACCOUNT PAGE
   ═══════════════════════════════════════════════════════ */
.woocommerce-account .wc-page-container {
    max-width: 1000px;
    margin: 0 auto;
}
.woocommerce-account .woocommerce {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 3rem;
    align-items: start;
}
@media (max-width: 768px) {
    .woocommerce-account .woocommerce { grid-template-columns: 1fr; }
}

/* Account navigation */
.woocommerce-MyAccount-navigation ul {
    list-style: none;
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid var(--color-border);
    position: sticky;
    top: 100px;
}
.woocommerce-MyAccount-navigation ul li a {
    display: flex;
    align-items: center;
    padding: .875rem 1.25rem;
    font-weight: 500;
    font-size: .9rem;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border);
    text-decoration: none;
    transition: all .2s;
}
.woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: none; }
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
    background: var(--color-primary-xlight);
    color: var(--color-primary);
    padding-left: 1.5rem;
}
.woocommerce-MyAccount-navigation ul li.is-active a { font-weight: 700; }

/* Account content */
.woocommerce-MyAccount-content {
    background: #fff;
    border-radius: 16px;
    padding: 2rem;
    border: 1px solid var(--color-border);
}
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
    font-size: 1.25rem;
    font-weight: 800;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid var(--color-primary-light);
}

/* Account orders table */
.woocommerce-orders-table {
    width: 100%;
}
.woocommerce-orders-table thead th {
    background: var(--color-light-bg);
    padding: .875rem 1rem;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-muted);
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}
.woocommerce-orders-table tbody td {
    padding: 1rem;
    border-bottom: 1px solid var(--color-border);
    font-size: .9rem;
    vertical-align: middle;
}
.woocommerce-orders-table .woocommerce-orders-table__cell-order-status mark {
    background: var(--color-primary-light);
    color: var(--color-primary-dark);
    padding: .25rem .75rem;
    border-radius: 50px;
    font-size: .75rem;
    font-weight: 700;
}
.woocommerce-orders-table .woocommerce-button { padding: .4rem 1rem !important; font-size: .8rem !important; }

/* Login/Register forms */
.woocommerce-account .woocommerce-form {
    max-width: 480px;
    background: #fff;
    padding: 2.5rem;
    border-radius: 16px;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-border);
}
.woocommerce-account .woocommerce-form p { margin-bottom: 1rem; }

/* ═══════════════════════════════════════════════════════
   MINI CART (in header drawer)
   ═══════════════════════════════════════════════════════ */
.woocommerce-mini-cart__empty-message {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--color-muted);
    font-size: .95rem;
}
.mini_cart_item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1rem 0;
    border-bottom: 1px solid var(--color-border);
}
.mini_cart_item img {
    width: 70px;
    height: 70px;
    object-fit: cover;
    border-radius: 8px;
    flex-shrink: 0;
}
.mini_cart_item .mini_cart_item_name {
    font-weight: 600;
    font-size: .9rem;
    color: var(--color-black);
    text-decoration: none;
    display: block;
    margin-bottom: .25rem;
}
.mini_cart_item .mini_cart_item_desc,
.mini_cart_item .quantity {
    font-size: .8rem;
    color: var(--color-muted);
}
.mini_cart_item .remove_from_cart_button {
    margin-left: auto;
    color: #dc2626;
    font-size: 1.1rem;
    flex-shrink: 0;
    text-decoration: none;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: #fee2e2;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
}
.mini_cart_item .remove_from_cart_button:hover { background: #dc2626; color: white; }

.woocommerce-mini-cart__total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0;
    border-top: 2px solid var(--color-border);
    margin-top: .5rem;
    font-weight: 700;
    font-size: 1rem;
}
.woocommerce-mini-cart__total strong { color: var(--color-primary-dark); }
.woocommerce-mini-cart__total .amount { font-size: 1.25rem; color: var(--color-primary-dark); }

.woocommerce-mini-cart__buttons {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    padding-top: 1rem;
}
.woocommerce-mini-cart__buttons a {
    display: block;
    text-align: center;
    padding: .875rem !important;
    border-radius: 50px !important;
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
    font-size: .95rem !important;
    text-decoration: none !important;
    transition: all .25s !important;
}
.woocommerce-mini-cart__buttons a.checkout {
    background: var(--color-primary) !important;
    color: white !important;
    box-shadow: var(--shadow-green) !important;
}
.woocommerce-mini-cart__buttons a.checkout:hover { background: var(--color-primary-dark) !important; }
.woocommerce-mini-cart__buttons a.cart {
    border: 2px solid var(--color-primary) !important;
    color: var(--color-primary) !important;
    background: transparent !important;
}
.woocommerce-mini-cart__buttons a.cart:hover { background: var(--color-primary-xlight) !important; }

/* ═══════════════════════════════════════════════════════
   TRUST BAR (shared: cart & checkout)
   ═══════════════════════════════════════════════════════ */
.co-trust-bar {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem 1.5rem;
    justify-content: center;
    background: var(--color-primary-xlight);
    border: 1px solid rgba(60,185,90,.2);
    border-radius: 12px;
    padding: .85rem 2rem;
    margin-bottom: 1.5rem;
    font-size: .85rem;
    font-weight: 600;
    color: var(--color-primary-dark);
}

/* ═══════════════════════════════════════════════════════
   SELECT2 (WooCommerce country / state dropdowns)
   ═══════════════════════════════════════════════════════ */
.select2-container { width: 100% !important; }
.select2-container--default .select2-selection--single {
    height: auto !important;
    padding: .75rem 1rem !important;
    border: 2px solid var(--color-border) !important;
    border-radius: 8px !important;
    background: #fff !important;
    transition: border-color .2s !important;
    outline: none !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: normal !important;
    padding: 0 !important;
    color: var(--color-text) !important;
    font-size: .95rem !important;
    font-family: var(--font-body) !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100% !important;
    right: 10px !important;
}
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default:focus-within .select2-selection--single {
    border-color: var(--color-primary-dark) !important;
    box-shadow: 0 0 0 3px rgba(221,220,140,.25) !important;
}
.select2-dropdown {
    border: 2px solid var(--color-border) !important;
    border-radius: 8px !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.1) !important;
    font-family: var(--font-body) !important;
    font-size: .95rem !important;
}
.select2-results__option {
    padding: .65rem 1rem !important;
    color: var(--color-text) !important;
}
.select2-results__option--highlighted[aria-selected] {
    background: var(--color-primary-xlight) !important;
    color: var(--color-primary-dark) !important;
}
.select2-search--dropdown .select2-search__field {
    padding: .5rem .75rem !important;
    border: 2px solid var(--color-border) !important;
    border-radius: 6px !important;
    font-size: .9rem !important;
    outline: none !important;
}
.select2-search--dropdown .select2-search__field:focus {
    border-color: var(--color-primary-dark) !important;
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */

/* ── Tablet (≤ 900px) ── */
@media (max-width: 900px) {
    /* Page banner */
    .wc-page-banner { padding: 2rem 0 1.5rem; margin-bottom: 2rem; }

    /* Cart */
    .woocommerce-cart .cart_totals { max-width: 100%; position: static; }

    /* Checkout two-col collapses */
    .woocommerce-checkout .col2-set { grid-template-columns: 1fr; gap: 0; }
    #order_review { position: static; }
}

/* ── Mobile (≤ 768px) ── */
@media (max-width: 768px) {
    /* Page banner */
    .wc-page-banner { padding: 1.5rem 0 1.25rem; margin-bottom: 1.5rem; }
    .wc-page-banner h1 { font-size: 1.5rem; }

    /* Single product */
    .sp-main { padding: 1.5rem 0; }
    .product-gallery { margin-bottom: 1.5rem; }
    .gallery-main-wrap { border-radius: 12px; overflow: hidden; }
    .gallery-main-img { max-height: 300px; width: 100%; object-fit: contain; }
    .gallery-thumbs {
        display: flex;
        flex-wrap: wrap;
        gap: .5rem;
        margin-top: .75rem;
    }
    .gallery-thumb {
        width: 64px;
        height: 64px;
        object-fit: cover;
        border-radius: 8px;
        border: 2px solid transparent;
        cursor: pointer;
    }
    .gallery-thumb.active { border-color: var(--color-primary); }

    /* Product details */
    .product-details { padding: 0; }
    .woocommerce div.product .product_title { font-size: 1.5rem; }
    .woocommerce div.product p.price,
    .woocommerce div.product span.price { font-size: 1.5rem !important; }
    .woocommerce div.product form.cart { gap: .75rem; }
    .woocommerce div.product form.cart .single_add_to_cart_button {
        min-width: 0;
        width: 100%;
        padding: .875rem 1rem !important;
    }

    /* Trust badges row on product page */
    .product-trust-row { flex-wrap: wrap; gap: .5rem; }
    .ptr-item { font-size: .8rem; }

    /* Product tabs */
    .product-tabs-section .woocommerce-tabs { padding: 0 1rem; border-radius: 12px; }
    .product-tabs-section .woocommerce-tabs ul.tabs li a { padding: .75rem .875rem; font-size: .85rem; }

    /* Cart totals */
    .woocommerce-cart .cart_totals { max-width: 100%; position: static; }

    /* Account */
    .woocommerce-account .woocommerce { grid-template-columns: 1fr; }
    .woocommerce-MyAccount-navigation ul { position: static; margin-bottom: 1.5rem; }

    /* Mini cart drawer — ensure it doesn't overflow screen height */
    .mini-cart-body { max-height: calc(100vh - 200px); overflow-y: auto; }

    /* Mini cart items */
    .mini_cart_item img { width: 56px; height: 56px; }

    /* Order received */
    .woocommerce-thankyou-order-received { font-size: 1.25rem; padding: 1.5rem; }
    .woocommerce-order-details,
    .woocommerce-customer-details { padding: 1.25rem; }
}

/* ── Small phones (≤ 480px) ── */
@media (max-width: 480px) {
    /* Page banner */
    .wc-page-banner { padding: 1.25rem 0 1rem; }
    .wc-page-banner h1 { font-size: 1.25rem; }

    /* Single product gallery */
    .gallery-main-img { max-height: 240px; }
    .gallery-thumb { width: 52px; height: 52px; }

    /* ATC button full width */
    .woocommerce div.product form.cart { flex-direction: column; align-items: stretch; }
    .woocommerce div.product form.cart .qty { width: 100% !important; height: 48px !important; }

    /* Cart table — hide thumbnail col, reorganize */
    .woocommerce-cart table.cart thead { display: none; }
    .woocommerce-cart table.cart tr {
        display: flex;
        flex-wrap: wrap;
        padding: 1rem;
        border-bottom: 1px solid var(--color-border);
    }
    .woocommerce-cart table.cart td { border: none !important; padding: .25rem .5rem !important; }
    .woocommerce-cart table.cart .product-thumbnail { width: 70px; }

    /* Empty cart */
    .empty-cart-wrap { padding: 3rem 1rem; }
    .empty-cart-icon { font-size: 3.5rem; }
    .empty-cart-wrap h2 { font-size: 1.5rem; }

    /* Cart trust strip */
    .cart-trust-strip { padding: 1rem; gap: .75rem; }
    .ct-item { font-size: .8rem; }

    /* Checkout form */
    .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
    .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
        grid-template-columns: 1fr !important;
    }

    /* Account login form */
    .woocommerce-account .woocommerce-form { padding: 1.5rem; }

    /* Mini cart */
    .woocommerce-mini-cart__buttons a { padding: .75rem !important; font-size: .875rem !important; }
}
