/* =====================================================================
 * Side-cart / mini-cart drawer  —  Oath-style to match the checkout.
 * Loaded site-wide (the drawer can open on any page).
 * Targets BOTH Elementor "Menu Cart" and the standard WooCommerce mini-cart
 * markup, so it applies regardless of which one powers the drawer.
 * ===================================================================== */

:root {
    --clpe-ink: #1a1a1a;
    --clpe-muted: #6b7177;
    --clpe-line: #e3e3e3;
    --clpe-bg: #ffffff;
    --clpe-bg-soft: #f7f7f7;
    --clpe-btn: #2f2f2f;
    --clpe-btn-hover: #000000;
    --clpe-accent: #2D6A4F;
    --clpe-accent-hover: #245a42;
    --clpe-accent-soft: #eaf3ef;
    --clpe-radius: 10px;
}

/* ---------- Box-sizing reset so nothing overflows the drawer ---------- */
.elementor-menu-cart__container,
.elementor-menu-cart__container *,
.widget_shopping_cart,
.widget_shopping_cart * {
    box-sizing: border-box;
}

/* ---------- Panel shell ---------- */
/* Do NOT set width here — Elementor controls the drawer panel width.
   overflow-x:hidden + box-sizing reset keep inner content from spilling. */
.elementor-menu-cart__main,
.widget_shopping_cart .widget_shopping_cart_content,
.woocommerce.widget_shopping_cart .widget_shopping_cart_content {
    background: var(--clpe-bg);
    color: var(--clpe-ink);
    padding: 8px 20px 20px;
    overflow-x: hidden;
}

/* Flex-column layout so products scroll and footer pins to the bottom */
.elementor-menu-cart__main {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100%;
}
.elementor-menu-cart__products {
    flex: 1 1 auto;
}
/* Both Elementor footer structures pushed to the bottom */
.elementor-menu-cart__footer-state,
.elementor-menu-cart__footer-buttons {
    margin-top: auto;
}

/* Keep every inner content block within the panel width (not the panel itself). */
.elementor-menu-cart__products,
.elementor-menu-cart__footer-state,
.elementor-menu-cart__footer-buttons,
.elementor-menu-cart__subtotal,
ul.woocommerce-mini-cart,
.woocommerce-mini-cart__total,
.woocommerce-mini-cart__buttons {
    width: 100%;
    max-width: 100%;
}

/* ---------- Product rows ---------- */
.elementor-menu-cart__products,
ul.woocommerce-mini-cart.cart_list,
ul.cart_list {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    /* prevent Elementor flex/grid gap between items */
    display: block !important;
    gap: 0 !important;
}

.elementor-menu-cart__product,
li.woocommerce-mini-cart-item,
li.mini_cart_item {
    position: relative !important;
    display: flex !important;
    align-items: flex-start !important;  /* gap above name comes from Elementor overriding this */
    gap: 14px !important;
    margin: 0 !important;
    padding: 12px 0 12px 28px !important;
    border: 0 !important;
    border-bottom: 1px solid var(--clpe-line) !important;
    box-sizing: border-box !important;
}

/* Thumbnail — rounded, light bordered box like the checkout summary */
.elementor-menu-cart__product-image,
li.woocommerce-mini-cart-item img,
li.mini_cart_item img {
    flex: 0 0 64px !important;
    align-self: flex-start !important;
    width: 64px !important;
    height: 64px !important;
    object-fit: cover !important;
    margin: 0 !important;
    border: 1px solid var(--clpe-line) !important;
    border-radius: 8px !important;
    background: var(--clpe-bg-soft) !important;
    float: none !important;
}
.elementor-menu-cart__product-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
}

/* Column wrapper injected/tagged by script.js — groups name + price+qty */
.clpe-product-info,
.elementor-menu-cart__product-details {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 0 !important;
    min-width: 0 !important;
    gap: 4px !important;
    align-self: flex-start !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Name + price block */
.elementor-menu-cart__product-name,
.elementor-menu-cart__product-name a,
.clpe-product-info .elementor-menu-cart__product-name,
li.woocommerce-mini-cart-item > a:not(.remove),
li.mini_cart_item > a:not(.remove) {
    display: block !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 1.35 !important;
    color: var(--clpe-ink) !important;
    text-decoration: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.elementor-menu-cart__product-price,
li.woocommerce-mini-cart-item .quantity,
li.mini_cart_item .quantity {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 13px;
    color: var(--clpe-muted);
}
.elementor-menu-cart__product-price .amount,
li.mini_cart_item .quantity .amount {
    color: var(--clpe-ink);
    font-weight: 600;
}

/* Remove (×) button — top-LEFT (House-of-Aminos layout).
   Force-visible: Porto/theme CSS can hide a.remove with display:none. */
.elementor-menu-cart__product-remove,
li.woocommerce-mini-cart-item a.remove,
li.mini_cart_item a.remove {
    position: absolute !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    top: 18px;
    left: 0;
    right: auto;
    width: 20px;
    height: 20px;
    line-height: 18px;
    text-align: center;
    border-radius: 999px;
    color: var(--clpe-muted) !important;
    font-size: 16px;
    background: transparent !important;
    border: 0 !important;
    z-index: 2;
    transition: color .15s ease, background .15s ease;
}
/* The actual link/button inside the Elementor remove wrapper */
.elementor-menu-cart__product-remove a,
.elementor-menu-cart__product-remove button {
    display: block !important;
    width: 100%;
    height: 100%;
    color: inherit !important;
    text-decoration: none !important;
    font-size: inherit;
    line-height: inherit;
    text-align: center;
    background: transparent !important;
    border: 0 !important;
}
li.woocommerce-mini-cart-item a.remove:hover,
li.mini_cart_item a.remove:hover,
.elementor-menu-cart__product-remove:hover,
.elementor-menu-cart__product-remove:hover a {
    color: #c0392b !important;
    background: var(--clpe-bg-soft) !important;
}

/* ---------- Subtotal ---------- */
.elementor-menu-cart__subtotal,
.woocommerce-mini-cart__total.total,
p.woocommerce-mini-cart__total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin: 0;
    padding: 18px 0;
    border: 0;
    border-top: 2px solid var(--clpe-ink);
    font-size: 16px;
    font-weight: 700;
    color: var(--clpe-ink);
}
.elementor-menu-cart__subtotal strong,
.woocommerce-mini-cart__total.total strong {
    font-weight: 700;
}
.woocommerce-mini-cart__total .amount,
.elementor-menu-cart__subtotal .amount {
    font-size: 18px;
    font-weight: 700;
    color: var(--clpe-ink);
}

/* ---------- Buttons ---------- */
.elementor-menu-cart__footer-buttons,
.woocommerce-mini-cart__buttons.buttons,
p.woocommerce-mini-cart__buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin: 0;
    padding: 4px 0 8px;
}
.elementor-menu-cart__footer-buttons .elementor-button,
.woocommerce-mini-cart__buttons .button {
    display: block;
    width: 100%;
    text-align: center;
    padding: 15px 24px;
    border-radius: var(--clpe-radius);
    font-size: 15px;
    font-weight: 600;
    letter-spacing: .2px;
    text-transform: none;
    transition: background .15s ease, color .15s ease;
}

/* Primary = Checkout (accent blue, House-of-Aminos style). */
.elementor-menu-cart__footer-buttons .elementor-button--checkout,
.elementor-menu-cart__footer-buttons a.elementor-button[href*="checkout"],
.woocommerce-mini-cart__buttons .button.checkout {
    background: var(--clpe-accent) !important;
    color: #fff !important;
    border: 1px solid var(--clpe-accent) !important;
    order: 1;
}
.elementor-menu-cart__footer-buttons .elementor-button--checkout:hover,
.elementor-menu-cart__footer-buttons .elementor-button--checkout:focus,
.elementor-menu-cart__footer-buttons a.elementor-button[href*="checkout"]:hover,
.woocommerce-mini-cart__buttons .button.checkout:hover {
    background: var(--clpe-accent-hover) !important;
    border-color: var(--clpe-accent-hover) !important;
    color: #fff !important;
}

/* "View cart" — hidden; "Continue Shopping" (injected) replaces it to match
   the House-of-Aminos drawer (single Checkout button + text link). */
.elementor-menu-cart__footer-buttons .elementor-button--view-cart,
.woocommerce-mini-cart__buttons .button.wc-forward:not(.checkout),
.woocommerce-mini-cart__buttons .button:not(.checkout) {
    display: none !important;
}

/* Price + qty flex row (replaces the "N × $price" element) */
.clpe-price-qty {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 4px;
    overflow: visible;  /* never clip the + button */
}
.clpe-item-price,
.clpe-item-price .amount,
.clpe-item-price span {
    font-size: 14px;
    font-weight: 600;
    color: var(--clpe-ink);
    flex: 1 1 auto;     /* grow to fill space, push qty to the right */
    min-width: 0;
}
/* Qty control must never shrink so the + button is never cut */
.clpe-qty-ctrl {
    flex-shrink: 0 !important;
}

/* "Continue Shopping" — plain text link.
   Uses <a> tag so Porto's button rules don't apply.
   Extra !important guards against any global a { } overrides. */
a.clpe-continue-shopping,
.clpe-continue-shopping {
    display: block !important;
    width: 100%;
    margin: 10px 0 4px !important;
    padding: 4px !important;
    background: none !important;
    background-color: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: var(--clpe-muted) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    text-align: center !important;
    text-decoration: none !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    cursor: pointer;
}
a.clpe-continue-shopping:hover,
.clpe-continue-shopping:hover {
    color: var(--clpe-ink) !important;
    text-decoration: underline !important;
    background: none !important;
}

/* ---------- Inline quantity controls ---------- */
.clpe-qty-ctrl {
    display: inline-flex;
    align-items: center;
    margin-top: 8px;
    border: 1px solid var(--clpe-line);
    border-radius: 6px;
    overflow: hidden;
}
.clpe-qty-btn {
    background: var(--clpe-bg-soft);
    border: 0;
    width: 28px;
    height: 28px;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    color: var(--clpe-ink);
    padding: 0;
    transition: background .15s;
    flex: 0 0 28px;
}
.clpe-qty-btn:hover {
    background: var(--clpe-line);
}
.clpe-qty-val {
    min-width: 30px;
    text-align: center;
    font-size: 14px;
    font-weight: 600;
    color: var(--clpe-ink);
    padding: 0 4px;
}
.clpe-qty-ctrl.clpe-qty-loading {
    opacity: 0.5;
    pointer-events: none;
}

/* Empty-cart message */
.woocommerce-mini-cart__empty-message,
.elementor-menu-cart__products .elementor-menu-cart__product--empty {
    color: var(--clpe-muted);
    font-size: 14px;
    padding: 18px 0;
}

/* ---------- Free-shipping progress bar (Oath style) ---------- */
.clpe-fs-bar {
    padding: 12px 0 10px;
    border-top: 1px solid var(--clpe-line);
}
.clpe-fs-msg {
    margin: 0 0 8px;
    font-size: 13px;
    color: var(--clpe-muted);
    line-height: 1.4;
}
.clpe-fs-bar.is-free .clpe-fs-msg {
    color: #2e7d32;
}
.clpe-fs-check {
    color: #2e7d32;
    font-weight: 700;
}
.clpe-fs-track {
    height: 5px;
    background: var(--clpe-line);
    border-radius: 99px;
    overflow: hidden;
}
.clpe-fs-fill {
    height: 100%;
    background: #2e7d32;
    border-radius: 99px;
    transition: width .4s ease;
}

/* ---------- Qty controls — compact Oath-style ---------- */
.clpe-qty-ctrl {
    display: inline-flex;
    align-items: center;
    gap: 0;
    margin-top: 6px;
    border: 1px solid var(--clpe-line);
    border-radius: 6px;
    overflow: hidden;
}
.clpe-qty-btn {
    background: var(--clpe-bg-soft);
    border: 0;
    width: 26px;
    height: 26px;
    font-size: 15px;
    line-height: 1;
    cursor: pointer;
    color: var(--clpe-ink);
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 26px;
    transition: background .15s;
}
.clpe-qty-btn:hover { background: var(--clpe-line); }
.clpe-qty-val {
    min-width: 28px;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--clpe-ink);
    padding: 0 3px;
    line-height: 26px;
}
.clpe-qty-ctrl.clpe-qty-loading {
    opacity: 0.4;
    pointer-events: none;
}

/* ---------- "Got a discount code?" collapsible ---------- */
.clpe-cart-discount {
    border: 1px solid var(--clpe-line);
    border-radius: var(--clpe-radius);
    margin: 14px 0 4px;
    overflow: hidden;
}
.clpe-cart-discount-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 13px 16px;
    background: var(--clpe-bg) !important;
    background-color: #ffffff !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    color: var(--clpe-ink) !important;
    text-align: left;
    letter-spacing: 0 !important;
    text-transform: none !important;
}
.clpe-cart-discount-toggle .clpe-disc-chevron {
    color: var(--clpe-muted) !important;
    transition: transform .2s ease;
    flex: 0 0 auto;
}
.clpe-cart-discount-toggle.is-open .clpe-disc-chevron {
    transform: rotate(180deg);
}
.clpe-cart-discount-panel {
    display: flex;
    gap: 8px;
    padding: 0 16px 14px;
}
.clpe-cart-discount-panel[hidden] {
    display: none;
}
.clpe-coupon-input {
    flex: 1 1 auto;
    min-width: 0;
    height: 42px;
    padding: 0 12px;
    border: 1px solid var(--clpe-line);
    border-radius: 8px;
    font-size: 14px;
    color: var(--clpe-ink);
    background: var(--clpe-bg-soft);
}
.clpe-coupon-input:focus {
    outline: none;
    border-color: var(--clpe-accent);
    background: var(--clpe-bg);
}
.clpe-coupon-apply {
    flex: 0 0 auto;
    height: 42px;
    padding: 0 18px;
    border: 0;
    border-radius: 8px;
    background: var(--clpe-ink);
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}
.clpe-coupon-apply:hover { background: #000; }
.clpe-coupon-apply:disabled { opacity: .6; cursor: default; }

/* ---------- Password reset page — sign-up wall style ---------- */
/* The page uses the [lost_password_form] shortcode which renders inside
   .clpe-portal-wrapper (our custom template). Porto's page template
   provides the outer shell; these rules make it look like the access gate. */
.clpe-reset-wrapper {
    max-width: 480px;
    margin: 0 auto;
    padding: 32px 24px;
}
.clpe-reset-intro {
    font-size: 14px;
    color: #6b7177;
    margin: 0 0 24px;
    line-height: 1.5;
}
.clpe-reset-submit {
    display: block;
    width: 100%;
    padding: 14px 24px;
    background: #2D6A4F;
    color: #fff;
    border: 0;
    border-radius: 6px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    text-align: center;
    letter-spacing: .2px;
    transition: background .15s;
}
.clpe-reset-submit:hover { background: #245a42; }
.clpe-reset-back {
    margin-top: 16px;
    text-align: center;
    font-size: 13px;
}
.clpe-reset-back a {
    color: #6b7177;
    text-decoration: none;
}
.clpe-reset-back a:hover { color: #1a1a1a; text-decoration: underline; }
/* WooCommerce success / error notices on the reset page */
.page-slug-password-reset .woocommerce-message,
.page-slug-password-reset .woocommerce-error,
.page-slug-password-reset .woocommerce-info {
    border-radius: 6px;
    font-size: 14px;
    margin-bottom: 20px;
}
.page-slug-password-reset .woocommerce-message {
    background: #eaf3ef;
    border-left-color: #2D6A4F;
    color: #1a4a34;
}

