/* ============================================================
   WOOCOMMERCE — Cart, Checkout, Account, Product buttons,
   Cart sidebar (xoo-wsc), Autoship plugin
   ============================================================ */


/* ── General WooCommerce typography ── */
body .woocommerce p {
    font-size: clamp(16px, 2.5vw, 20px);
    line-height: 1.5;
    color: #1B1816;
    font-family: 'Neue Haas Grotesk Display Pro roman';
}
body .woocommerce p a { color: var(--co-cta); }
.woocommerce { font-family: 'Neue Haas Grotesk Display Pro roman'; }
.woocommerce .products p { font-size: 16px; }


/* ── Notices ── */
.woocommerce .woocommerce-error,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-message { color: #fff !important; border-radius: 11px; }
.woocommerce .woocommerce-info > a.wc-forward { color: #fff !important; border-color: #fff !important; }
.woocommerce-info { border-radius: 11px; padding: 20px !important; margin-bottom: 30px; }
.woocommerce-info .button::after { display: none; }
.woocommerce-notices-wrapper ~ p { margin-bottom: 2rem !important; }
.woocommerce form .form-row .required { color: var(--co-cta); }
.woocommerce form .form-row.woocommerce-invalid label { color: var(--co-cta); }


/* ── Buttons ── */
.woocommerce .button {
    display: inline-flex !important;
    align-items: center;
    gap: 5px;
    margin-bottom: 0 !important;
    justify-content: center;
    padding: 6px 20px !important;
    border: 1px solid var(--co-cta) !important;
    color: #F9F8F4 !important;
    background: var(--co-cta) !important;
    font-family: 'Neue Haas Grotesk Display Pro roman';
    font-weight: 400 !important;
    letter-spacing: 1px;
    border-radius: 50px !important;
    font-size: clamp(16px, 2.5vw, 20px) !important;
}
.woocommerce .button:hover .icon_button-e-commerce { width: 25px; }
.woocommerce .button .icon_button-e-commerce { width: 0; transition: 0.5s all; }
.woocommerce .button::after { display: none; }
.woocommerce .button:disabled { pointer-events: none; }
.woocommerce .woocommerce-info .button {
    border: 1px solid var(--co-cta-dark) !important;
    color: var(--co-cta-dark) !important;
    background: var(--co-cta) !important;
    letter-spacing: 1px;
    line-height: 1.4 !important;
}
.woocommerce-Button { border-radius: 35px !important; color: #fff !important; }
.woocommerce-Button.wc-forward.button:hover {
    padding-right: 20px;
    background: var(--co-cta-dark) !important;
    color: #ded7cc !important;
}


/* ── Add to cart button ── */
.single_add_to_cart_button { gap: 40px !important; }
.single_add_to_cart_button:hover { color: #fff !important; }
body.et-db #page-container #et-boc .et-l .et_pb_section .et_pb_wc_add_to_cart form .single_add_to_cart_button:hover { color: #fff !important; }
body.et-db #page-container #et-boc .et-l .et_pb_section .et_pb_wc_add_to_cart form .single_add_to_cart_button:hover .woocommerce-Price-amount bdi { color: #fff !important; }
.single_add_to_cart_button .icon_button-e-commerce { display: none; }
.et_pb_wc_price { display: none; }
.add_to_cart_button .single_add_to_cart_button {
    width: 100%;
    display: flex !important;
    justify-content: center;
    gap: 40px;
    letter-spacing: 2px;
}
.add_to_cart_button bdi { color: var(--co-cta-dark) !important; font-size: 27px; }
.add_to_cart_button .single_add_to_cart_button > .et_pb_module_inner::after,
.add_to_cart_button .single_add_to_cart_button span.woocommerce-Price-amount.amount::after {
    content: "";
    position: absolute;
    top: 50%;
    height: 100%;
    width: 1px;
    background: var(--co-cta-dark);
    left: -20px;
    transform: translateY(-50%);
}
.add_to_cart_button .single_add_to_cart_button span.woocommerce-Price-amount.amount { position: relative; }
.add_to_cart_button .single_add_to_cart_button:hover span.woocommerce-Price-amount.amount::after { background: #fff; }
.add_to_cart_button .single_add_to_cart_button:hover > .et_pb_module_inner::after { background: #fff; }
body #page-container .et_pb_section .et_pb_wc_add_to_cart_0_tb_body .button { font-size: 27px !important; }
body #page-container .et_pb_section .et_pb_wc_add_to_cart_0_tb_body .button:hover { background: var(--co-cta) !important; }


/* ── Price ── */
.woocommerce div.product p.price del bdi {
    font-family: 'Neue Haas Grotesk Display Pro roman';
    font-size: 27px;
}
.woocommerce div.product p.price del { opacity: 1; }
.woocommerce div.product .single_add_to_cart_button:hover p.price del { text-decoration-color: #fff !important; }
.sticky-on-price-product .et_pb_text_inner { white-space: nowrap; }
.sticky-on-price-product > .et_pb_text_inner .woocommerce-Price-amount.amount { display: none; }
.sticky-on-price-product .price * { font-size: 27px; color: #fff; }
.sticky-on-price-product p.price { line-height: 1; }
.pric-move-item { display: none; }
.subs-box-old { display: none; }


/* ── Product tables ── */
.woocommerce table.shop_table { border: 1px solid #ded7cc; border-radius: 5px; }
.woocommerce table.shop_table td,
.woocommerce-cart .cart-collaterals .cart_totals tr th,
.woocommerce-cart .cart-collaterals .cart_totals tr td { border-top: 1px solid #ded7cc; }
.woocommerce table.shop_table th,
.woocommerce table.shop_table td { padding: 0.5rem !important; }
.woocommerce table.shop_table th { font-weight: 400 !important; color: #1B1816; }
.woocommerce table.shop_table tbody th,
.woocommerce table.shop_table tfoot td,
.woocommerce table.shop_table tfoot th {
    font-weight: 700;
    border-top: 1px solid #ded7cc;
    color: var(--co-cta);
}
.woocommerce table.shop_table { font-size: clamp(16px, 2.5vw, 20px); }


/* ── Cart ── */
.woocommerce-cart-form { font-size: 20px; }
.woocommerce .quantity input.qty {
    background: transparent;
    border: 1px solid #ded7cc;
    font-size: 20px;
    padding: 0;
    color: #1B1816;
    font-family: 'Neue Haas Grotesk Display Pro roman';
}
.cart_totals h2 { font-size: clamp(27px, 3.5vw, 40px); }
.cart_totals table { font-size: clamp(20px, 3.5vw, 27px); }
.woocommerce .wc-block-cart-items,
.woocommerce .wc-block-components-sidebar { font-size: clamp(20px, 3.5vw, 27px); }
.wc-proceed-to-checkout .checkout-button { width: 100%; display: flex; justify-content: center; }
.woocommerce-cart td.product-name > a { margin-top: 15px !important; display: block; text-align: left; }


/* ── Cart sidebar (xoo-wsc plugin) ── */
.xoo-wsc-items-count { background-color: var(--co-cta); }
.xoo-wsc-basket { color: var(--co-cta); }
.xoo-wsc-container, .xoo-wsc-slider { max-width: 500px; right: -500px; }
span.xoo-wsch-close { color: #1b1816; font-size: 30px; }
.xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn,
.xoo-wsc-container .xoo-wsc-btn {
    background-color: var(--co-cta);
    border: 1px solid var(--co-cta);
    border-radius: 35px;
    font-size: 20px;
    font-family: 'Neue Haas Grotesk Display Pro roman';
    font-weight: 800;
    padding: 12px 20px;
    letter-spacing: 1px;
}
.xoo-wsc-ft-buttons-cont a.xoo-wsc-ft-btn:hover,
.xoo-wsc-container .xoo-wsc-btn:hover {
    background-color: var(--co-cta);
    color: #f9f8f4;
    border: 1px solid var(--co-cta);
}
.xoo-wsc-btn:hover .amount { color: #f9f8f4; }
.xoo-wsc-body { background-color: var(--co-cta-bg); }
.xoo-wsc-footer { background-color: var(--co-cta-bg); color: #1b1816; box-shadow: none; }
.xoo-wsc-header { color: #1b1816; background: #f9f8f4d6; border-bottom: 2px solid #eee; }
.xoo-wsc-products:not(.xoo-wsc-pattern-card) .xoo-wsc-product {
    padding: 15px; margin: 0; border-radius: 0; box-shadow: none; background-color: transparent;
}
.xoo-wsc-img-col img { vertical-align: bottom; border-radius: 10px !important; }
span.xoo-wsc-pname, span.xoo-wsc-pname a { font-weight: 400; }
.xoo-wsc-products:not(.xoo-wsc-pattern-card) .xoo-wsc-img-col { width: 20%; }
.xoo-wsc-container .xoo-wsc-btn img { width: 0; transition: 0.5s all; transform: translateX(20px); }
.xoo-wsc-ft-btn:hover img { width: 22px; transform: translateX(0); margin-left: 5px; }


/* ── Checkout ── */
#add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment { background: var(--co-cta); }
#add_payment_method #payment div.payment_box,
.woocommerce-cart #payment div.payment_box,
.woocommerce-checkout #payment div.payment_box { color: #1B1816; }
#add_payment_method #payment div.payment_box::before,
.woocommerce-cart #payment div.payment_box::before,
.woocommerce-checkout #payment div.payment_box::before {
    border: 1em solid #e8e0e0;
    border-right-color: transparent;
    border-left-color: transparent;
    border-top-color: transparent;
}
.woocommerce-checkout #main-content .cart-subtotal td { border-top: 1px solid #ded7cc; }
#add_payment_method #payment div.payment_box,
.woocommerce-cart #payment div.payment_box,
.woocommerce-checkout #payment div.payment_box { margin: 1em 0 0; }
.woocommerce-cart form .form-row .input-text,
.woocommerce-cart table.cart td.actions .coupon .input-text { border: 1px solid #ded7cc !important; }
.woocommerce form .form-row .input-text,
.woocommerce-cart table.cart td.actions .coupon .input-text {
    font-size: 16px !important;
    background: transparent !important;
    border: 1px solid #707070 !important;
    height: 50px;
    padding: 1rem !important;
    color: #1B1816 !important;
    font-family: 'Neue Haas Grotesk Display Pro roman';
    border-radius: 5px !important;
}
.woocommerce form .form-row input.input-text::placeholder { color: #1B1816; }
body .woocommerce form .form-row textarea.input-text {
    min-height: 80px !important;
    padding-top: 10px !important;
    color: #1B1816 !important;
    border: none;
    border-radius: 0;
}
body .woocommerce form .form-row textarea.input-text::placeholder { color: #1b1816; }
.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register { border-color: #ded7cc; border-radius: 11px; }
.woocommerce .col2-set, .woocommerce-page .col2-set { margin-bottom: 30px; margin-top: 30px; }
#wc-stripe-express-checkout-button-separator { margin-top: 30px !important; }
#order_review_heading { padding-bottom: 1rem; margin-top: 2rem; }
#wc-stripe-express-checkout-element-link { border-radius: 50px; overflow: hidden; }
.et_pb_wc_checkout_order_details #customer_details,
.et_pb_wc_checkout_order_details #order_review_heading { display: none; }


/* ── Select2 ── */
.selection .select2-selection {
    background: transparent;
    border: 1px solid #707070;
    border-radius: 5px !important;
}
.selection .select2-selection span { padding: 15px !important; color: #1B1816 !important; font-size: 16px; }
.selection .select2-selection span span { padding: 0 !important; }
.select2-search--dropdown .select2-search__field {
    padding: 15px; width: 100%; box-sizing: border-box;
    background: transparent; border: 1px solid #ded7cc !important; border-radius: 5px;
}
.select2-container .select2-dropdown, .select2-container .select2-selection { background-color: #fff; border-radius: 0; }
span.select2-dropdown.select2-dropdown--above { background: #fff; }
.select2-container .select2-selection { background-color: transparent; }
.select2-results__option[aria-selected], .select2-results__option[data-selected] {
    font-family: 'Neue Haas Grotesk Display Pro roman';
    font-weight: 300;
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected] { background: var(--co-cta); }
.payment_method_stripe > label { color: #fff; }


/* ── My Account ── */
.woocommerce-Address h2 {
    font-family: 'Neue Haas Grotesk Display Pro roman';
    font-size: 27px;
    color: var(--co-cta-dark);
}
.woocommerce-account .addresses .title .edit {
    float: left !important;
    font-size: clamp(16px, 2.5vw, 20px);
    line-height: 1.5;
    color: var(--co-cta);
}
.woocommerce-account .woocommerce-MyAccount-content h2 {
    font-family: 'GT Alpina Fine';
    color: var(--co-cta-dark) !important;
    font-size: clamp(27px, 3.5vw, 40px);
    letter-spacing: 1px !important;
}
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; }
.woocommerce-MyAccount-navigation ul a { color: #1B1816; font-size: clamp(27px, 3.5vw, 40px); line-height: 1.2; }
.woocommerce-MyAccount-navigation ul .is-active a { color: var(--co-cta); }
.my_account_page ul { list-style: none; padding: 0; }
.my_account_page ul a { font-size: 31px; line-height: 1.4; color: var(--co-cta-dark); font-family: 'Neue Haas Grotesk Display Pro roman'; }
.woocommerce-MyAccount-content { margin-top: 20px; }
.woocommerce-orders-table__cell-order-actions { width: 20%; }
#account_display_name_description { font-size: 16px; }
#save-account-details-nonce ~ .woocommerce-Button.button { margin-top: 2rem !important; }
.woocommerce-EditAccountForm label { font-size: 20px; font-family: 'Neue Haas Grotesk Display Pro roman'; color: var(--co-cta-dark); }
.woocommerce-EditAccountForm.edit-account .woocommerce-Button.button::after { display: none; }
.woocommerce-EditAccountForm.edit-account .woocommerce-Button.button:hover {
    background: var(--co-cta-dark) !important;
    opacity: 1;
    border-color: var(--co-cta-dark) !important;
}
.woocommerce-Address-title a {
    padding: 6px 20px !important;
    border: 1px solid var(--co-cta) !important;
    color: #F9F8F4 !important;
    background: var(--co-cta) !important;
    font-family: 'Neue Haas Grotesk Display Pro roman';
    letter-spacing: 1px;
    border-radius: 50px !important;
    display: inline-flex !important;
    margin: 10px 0 20px;
    gap: 5px;
}
.woocommerce-Address-title a img { width: 0; transition: 0.5s all; }
.woocommerce-Address-title a:hover img { width: 25px; }
.woocommerce .woocommerce-MyAccount-content .button.view { line-height: 1.4 !important; }
.woocommerce-privacy-policy-text p .woocommerce-privacy-policy-link { color: var(--co-cta); }


/* ── Product thumbnail in cart ── */
.woocommerce .product-thumbnail a { display: flex; justify-content: center; }
.woocommerce .product-thumbnail a img { width: 100% !important; max-width: 80px; border-radius: 11px; }
.woocommerce-cart .autoship-frequency.active { display: none; }
.woocommerce-cart .woocommerce-cart-form__cart-item.cart_item .product-name p { display: none; }


/* ── On sale badge ── */
.woocommerce span.onsale,
.woocommerce-page span.onsale { background: transparent !important; font-size: 0; }
.woocommerce span.onsale,
.woocommerce-page span.onsale::after {
    content: "";
    background-image: url(/wp-content/uploads/2025/07/Best-value.png);
    position: absolute;
    width: 60px;
    height: 60px;
    background-repeat: no-repeat;
    background-size: contain;
    left: 0;
    top: 0;
}


/* ── Privacy / form ── */
.woocommerce form .form-row .input-checkbox { min-width: 15px; }


/* ── Autoship plugin ── */
.single-product .autoship-type.autoship-yes .autoship-label .autoship-checkout-price { display: none; }
.single-product .autoship-schedule-options .autoship-frequency.active,
.single-product .autoship-info-link { display: none; }
.single-product .autoship-type.autoship-yes .autoship-label {
    background-color: #E8E0E0;
    padding: 25px !important;
    border-radius: 11px;
    position: relative;
    margin-bottom: 30px;
    width: 100%;
    display: block;
}
.single-product .autoship-type.autoship-yes input[type=radio] {
    position: absolute; right: 25px; top: 25px; transform: scale(2);
}
.single-product .autoship-type.autoship-no .autoship-label {
    padding: 25px;
    border-radius: 11px;
    border: 1px solid #ded7cc;
    margin-bottom: 35px;
    position: relative;
    width: 100%;
    display: block;
    font-weight: 700;
}
.single-product .autoship-type.autoship-yes .autoship-label:before {
    content: 'Biggest Savings';
    background: var(--co-cta);
    color: #fff;
    padding: 2.5px 10px;
    border-radius: 7px;
    position: absolute;
    top: -15px;
    right: 20%;
}
.single-product .autoship-type.autoship-no input[type=radio] {
    position: absolute; right: 25px; top: 30px; transform: scale(2);
}
.single-product .autoship-type input[type=radio] { accent-color: var(--co-cta); }
.single-product .autoship-label .subs-price {
    font-family: 'Neue Haas Grotesk Display Pro roman';
    font-weight: 700;
    font-size: 175%;
    margin-bottom: 10px;
}
.single-product .autoship-label .subs-price s { opacity: 0.5; margin-right: 10px; }
.woocommerce-cart .autoship-type.autoship-no .autoship-label {
    padding: 15px 20px; border-radius: 11px; border: 1px solid #ded7cc;
    margin-bottom: 15px; position: relative; width: 100%; display: block; font-weight: 700; text-align: left;
}
.woocommerce-cart .autoship-type.autoship-yes .autoship-label {
    background-color: #E8E0E0; padding: 15px 20px; border-radius: 11px;
    position: relative; width: 100%; display: block; font-weight: 600; text-align: left;
}
.woocommerce-cart .autoship-type input[type=radio] {
    position: absolute; right: 25px; top: 24px; transform: scale(2); accent-color: var(--co-cta);
}
.woocommerce-cart .autoship-type.autoship-yes .autoship-label:before { content: 'Subscribe for just '; }
.woocommerce-cart .autoship-info-link { display: none; }
.woocommerce-cart .quantity input.qty { padding: 5px 10px; text-align: center; }


/* ── Responsive ── */
@media (max-width: 768px) {
    .woocommerce-orders-table__cell-order-actions { width: unset; }
    .woocommerce-page table.cart td.actions .coupon .button { width: 100%; }
    .woocommerce table.shop_table td,
    .woocommerce-cart .cart-collaterals .cart_totals tr th { background: transparent !important; }
    .woocommerce-cart-form__cart-item.cart_item td { padding: 10px !important; }
    table.cart tr, #main-content table.cart tr, #content-area table tr { padding: 0 !important; }
    .woocommerce table.shop_table_responsive tr td::before,
    .woocommerce-page table.shop_table_responsive tr td::before { font-weight: 400; }
    .woocommerce .col2-set, .woocommerce-page .col2-set { margin-bottom: 20px; margin-top: 20px; }
    #wc-stripe-express-checkout-button-separator { margin-top: 20px !important; }
    .woocommerce ul.products { grid-template-columns: 1fr 1fr; row-gap: 2rem; }
    .woocommerce form .form-row .input-text,
    .woocommerce-cart table.cart td.actions .coupon .input-text,
    .woocommerce-cart table.cart td.actions .coupon .input-text::placeholder { font-size: 16px !important; }
    .woocommerce table.shop_table th,
    .woocommerce table.shop_table td { padding: 0.5rem !important; }
    .my_account_page ul a { font-size: 27px; }
    .woocommerce-MyAccount-content p { font-size: 20px; }
    .woocommerce-EditAccountForm label { font-size: 20px; line-height: 1.5 !important; }
    #wc-stripe-new-payment-method,
    .woocommerce form .form-row .input-checkbox { min-width: 15px; height: 15px; margin-right: 5px !important; }
    .single-product .autoship-type.autoship-yes p { padding-bottom: 5px; }
}

@media (max-width: 980px) {
    .woocommerce-cart table.shop_table_responsive tr td.product-name:before { display: none; }
    .woocommerce-cart #coupon_code { margin-bottom: 10px; }
    .woocommerce ul.products { grid-template-columns: 1fr 1fr; gap: 16px; }
    .woocommerce span.onsale, .woocommerce-page span.onsale::after { width: 50px; height: 50px; }
}
