/*
 * D2 Checkout — Cart styling
 *
 * Forskønner WC's default cart-rendering med D2 design system.
 * /dit-koeb/ — single-column layout.
 */

/* ========================================
   WC cart wrapper integration
   ======================================== */
body.d2-checkout-page--cart .woocommerce {
    max-width: 1200px;
    margin: 0 auto;
}

/* ========================================
   Cart table som card
   ======================================== */
body.d2-checkout-page--cart .woocommerce-cart-form {
    background: var(--d2-surface, #fff);
    border: 1px solid var(--d2-line, #e8e8e8);
    border-radius: var(--d2-radius-lg, 12px);
    overflow: hidden;
    margin-bottom: 20px;
}

body.d2-checkout-page--cart table.shop_table {
    border: none;
    border-collapse: collapse;
    border-radius: 0;
    margin: 0;
    width: 100%;
}

body.d2-checkout-page--cart table.shop_table thead {
    background: var(--d2-surface-alt, #f7f7f7);
    border-bottom: 1px solid var(--d2-line, #e8e8e8);
}

body.d2-checkout-page--cart table.shop_table thead th {
    border: none;
    padding: 18px 24px;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif);
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--d2-ink-faint, #666);
}

body.d2-checkout-page--cart table.shop_table tbody tr {
    border-bottom: 1px solid var(--d2-line, #e8e8e8);
}

body.d2-checkout-page--cart table.shop_table tbody tr:last-child {
    border-bottom: none;
}

body.d2-checkout-page--cart table.shop_table td {
    border: none;
    padding: 24px;
    vertical-align: middle;
}

/* Thumbnail */
body.d2-checkout-page--cart .product-thumbnail {
    width: 96px;
}

body.d2-checkout-page--cart .product-thumbnail img {
    width: 80px;
    height: 80px;
    border-radius: var(--d2-radius-md, 6px);
    border: 1px solid var(--d2-line, #e8e8e8);
    background: var(--d2-surface-alt, #f7f7f7);
    object-fit: contain;
}

/* Product name */
body.d2-checkout-page--cart .product-name a {
    font-family: var(--d2-font-display, 'Montserrat', sans-serif);
    font-weight: 700;
    font-size: 15px;
    color: var(--d2-ink, #222);
    line-height: 1.35;
    text-decoration: none;
}

body.d2-checkout-page--cart .product-name a:hover {
    color: var(--d2-orange, #fc8902);
}

body.d2-checkout-page--cart .product-name dl.variation {
    margin: 8px 0 0;
    font-size: 13px;
    color: var(--d2-ink-faint, #666);
}

/* d2_required_input vises som key/value via wc_get_item_data */
body.d2-checkout-page--cart .product-name .wc-item-meta {
    margin: 8px 0 0;
    padding: 0;
    font-size: 13px;
    color: var(--d2-ink-faint, #666);
    list-style: none;
}

body.d2-checkout-page--cart .product-name .wc-item-meta li {
    margin: 4px 0;
}

/* Price */
body.d2-checkout-page--cart .product-price,
body.d2-checkout-page--cart .product-subtotal {
    font-family: var(--d2-font-display, 'Montserrat', sans-serif);
    font-weight: 700;
    font-size: 16px;
    color: var(--d2-ink, #222);
    font-variant-numeric: tabular-nums;
}

body.d2-checkout-page--cart .product-subtotal {
    text-align: right;
}

/* Quantity */
body.d2-checkout-page--cart .product-quantity {
    text-align: center;
    width: 180px;
}

body.d2-checkout-page--cart .product-quantity .quantity {
    display: inline-flex;
    align-items: center;
    border: 1.5px solid var(--d2-line-strong, #d8d8d8);
    border-radius: var(--d2-radius-md, 6px);
    overflow: hidden;
    background: var(--d2-surface, #fff);
    width: fit-content;
    margin: 0 auto;
}

body.d2-checkout-page--cart .product-quantity input.qty {
    width: 56px;
    height: 38px;
    border: none;
    text-align: center;
    font-family: var(--d2-font-body, Arial, sans-serif);
    font-size: 15px;
    font-weight: 600;
    color: var(--d2-ink, #222);
    background: var(--d2-surface, #fff);
    padding: 0;
    -moz-appearance: textfield;
}

body.d2-checkout-page--cart .product-quantity input.qty::-webkit-outer-spin-button,
body.d2-checkout-page--cart .product-quantity input.qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

body.d2-checkout-page--cart .product-quantity input.qty:focus {
    outline: none;
    background: var(--d2-orange-soft, rgba(252, 137, 2, 0.06));
}

/* Remove button */
body.d2-checkout-page--cart .product-remove {
    width: 60px;
    text-align: center;
}

body.d2-checkout-page--cart .product-remove a.remove {
    color: var(--d2-ink-faint, #666) !important;
    background: none !important;
    font-size: 22px !important;
    line-height: 1;
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--d2-radius-sm, 4px);
    transition: all 0.15s;
}

body.d2-checkout-page--cart .product-remove a.remove:hover {
    background: rgba(220, 38, 38, 0.08) !important;
    color: #dc2626 !important;
}

/* ========================================
   Cart footer (actions row)
   ======================================== */
body.d2-checkout-page--cart .actions {
    background: var(--d2-surface-alt, #f7f7f7);
    padding: 20px 28px !important;
    border-top: 1px solid var(--d2-line, #e8e8e8);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

/* Coupon (collapsible-style — simpel udgave) */
body.d2-checkout-page--cart .coupon {
    display: flex;
    gap: 8px;
    align-items: center;
}

body.d2-checkout-page--cart .coupon label {
    display: none;
}

body.d2-checkout-page--cart .coupon input[name="coupon_code"] {
    padding: 11px 14px;
    background: var(--d2-surface, #fff);
    border: 1px solid var(--d2-line-strong, #d8d8d8);
    border-radius: var(--d2-radius-md, 6px);
    font-family: var(--d2-font-body, Arial, sans-serif);
    font-size: 14px;
    color: var(--d2-ink-body, #292929);
    width: 200px;
}

body.d2-checkout-page--cart .coupon input[name="coupon_code"]:focus {
    outline: none;
    border-color: var(--d2-orange, #fc8902);
    box-shadow: 0 0 0 3px rgba(252, 137, 2, 0.15);
}

/* Buttons inside cart */
body.d2-checkout-page--cart button[name="apply_coupon"],
body.d2-checkout-page--cart button[name="update_cart"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 18px;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif);
    font-weight: 700;
    font-size: 13px;
    line-height: 1;
    border: 1.5px solid var(--d2-line-strong, #d8d8d8);
    background: transparent;
    color: var(--d2-ink, #222);
    border-radius: var(--d2-radius-md, 6px);
    cursor: pointer;
    transition: all 0.2s;
}

body.d2-checkout-page--cart button[name="apply_coupon"]:hover,
body.d2-checkout-page--cart button[name="update_cart"]:hover {
    border-color: var(--d2-ink, #222);
    color: var(--d2-ink, #222);
}

body.d2-checkout-page--cart button[name="update_cart"]:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* ========================================
   Cart collaterals (totals + checkout button)
   ======================================== */
body.d2-checkout-page--cart .cart-collaterals {
    display: flex;
    justify-content: flex-end;
    margin-top: 24px;
}

body.d2-checkout-page--cart .cart-collaterals .cart_totals {
    width: 100%;
    max-width: 520px;
    background: var(--d2-surface, #fff);
    border: 1px solid var(--d2-line, #e8e8e8);
    border-radius: var(--d2-radius-lg, 12px);
    padding: 28px 32px;
}

body.d2-checkout-page--cart .cart_totals h2 {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--d2-line, #e8e8e8);
    color: var(--d2-ink, #222);
}

body.d2-checkout-page--cart .cart_totals .shop_table {
    background: transparent;
    border: none;
}

body.d2-checkout-page--cart .cart_totals .shop_table th,
body.d2-checkout-page--cart .cart_totals .shop_table td {
    padding: 8px 0;
    border: none;
    background: transparent !important;
    font-family: var(--d2-font-body, Arial, sans-serif);
    font-size: 15px;
    color: var(--d2-ink-muted, #444);
    font-variant-numeric: tabular-nums;
}

body.d2-checkout-page--cart .cart_totals .order-total th,
body.d2-checkout-page--cart .cart_totals .order-total td {
    padding-top: 16px;
    border-top: 1px solid var(--d2-line, #e8e8e8) !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif);
    font-weight: 800;
    font-size: 24px;
    color: var(--d2-ink, #222);
    letter-spacing: -0.01em;
}

body.d2-checkout-page--cart .wc-proceed-to-checkout {
    margin-top: 20px;
    padding: 0;
}

body.d2-checkout-page--cart .wc-proceed-to-checkout .checkout-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 16px 28px;
    background: var(--d2-orange, #fc8902);
    color: #fff;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif);
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
    border: 1.5px solid var(--d2-orange, #fc8902);
    border-radius: var(--d2-radius-md, 6px);
    text-decoration: none;
    transition: all 0.2s;
}

body.d2-checkout-page--cart .wc-proceed-to-checkout .checkout-button:hover {
    background: var(--d2-orange-hover, #e57a00);
    border-color: var(--d2-orange-hover, #e57a00);
}

/* Shipping table */
body.d2-checkout-page--cart .cart_totals .cart-subtotal,
body.d2-checkout-page--cart .cart_totals .shipping {
    border-bottom: none;
}

/* ========================================
   Empty cart
   ======================================== */
body.d2-checkout-page--cart .cart-empty {
    background: var(--d2-surface, #fff);
    border: 1px solid var(--d2-line, #e8e8e8);
    border-radius: var(--d2-radius-lg, 12px);
    padding: 60px 40px;
    text-align: center;
    font-size: 18px;
    color: var(--d2-ink-muted, #444);
}

body.d2-checkout-page--cart .return-to-shop {
    text-align: center;
    margin-top: 20px;
}

body.d2-checkout-page--cart .return-to-shop .wc-backward {
    display: inline-flex;
    align-items: center;
    padding: 14px 28px;
    background: var(--d2-orange, #fc8902);
    color: #fff;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif);
    font-weight: 700;
    font-size: 15px;
    border-radius: var(--d2-radius-md, 6px);
    text-decoration: none;
    transition: all 0.2s;
}

body.d2-checkout-page--cart .return-to-shop .wc-backward:hover {
    background: var(--d2-orange-hover, #e57a00);
}

/* ========================================
   Responsive
   ======================================== */
@media (max-width: 980px) {
    body.d2-checkout-page--cart table.shop_table thead {
        display: none;
    }
    body.d2-checkout-page--cart table.shop_table tbody tr {
        display: block;
        padding: 20px;
    }
    body.d2-checkout-page--cart table.shop_table td {
        display: block;
        padding: 6px 0;
        text-align: left !important;
    }
    body.d2-checkout-page--cart .product-quantity {
        width: auto;
    }
    body.d2-checkout-page--cart .product-quantity .quantity {
        margin: 0;
    }
    body.d2-checkout-page--cart .actions {
        flex-direction: column;
        align-items: stretch;
    }
    body.d2-checkout-page--cart .coupon {
        flex-direction: column;
        align-items: stretch;
    }
    body.d2-checkout-page--cart .coupon input[name="coupon_code"] {
        width: 100%;
    }
}

/* ========================================
   FORCE-OVERRIDES — Divi/WC conflict resolution
   
   Divi's woocommerce-styling loader senere end vores CSS
   og bruger samme/højere specificity. Vi tvinger vores
   styling med !important på kritiske visuelle properties.
   ======================================== */

/* "Gå til kassen" — primary CTA, orange fyldt */
body.d2-checkout-page--cart .wc-proceed-to-checkout .checkout-button,
body.d2-checkout-page--cart a.checkout-button {
    background: var(--d2-orange, #fc8902) !important;
    color: #fff !important;
    border: 1.5px solid var(--d2-orange, #fc8902) !important;
    padding: 16px 28px !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    line-height: 1 !important;
    text-decoration: none !important;
    border-radius: var(--d2-radius-md, 6px) !important;
    text-shadow: none !important;
    box-shadow: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    text-align: center !important;
}

body.d2-checkout-page--cart .wc-proceed-to-checkout .checkout-button:hover,
body.d2-checkout-page--cart a.checkout-button:hover {
    background: var(--d2-orange-hover, #e57a00) !important;
    border-color: var(--d2-orange-hover, #e57a00) !important;
    color: #fff !important;
}

/* "Fortsæt med at handle" (wc-forward i success notice) — ghost-dark */
body.d2-checkout-page--cart .woocommerce-message .wc-forward,
body.d2-checkout-page--cart .woocommerce-message a.button,
body.d2-checkout-page--cart .button.wc-forward:not(.checkout-button) {
    background: transparent !important;
    color: var(--d2-ink, #222) !important;
    border: 1.5px solid var(--d2-line-strong, #d8d8d8) !important;
    padding: 10px 18px !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    line-height: 1 !important;
    border-radius: var(--d2-radius-md, 6px) !important;
    text-decoration: none !important;
    text-shadow: none !important;
    box-shadow: none !important;
}

body.d2-checkout-page--cart .woocommerce-message .wc-forward:hover,
body.d2-checkout-page--cart .woocommerce-message a.button:hover,
body.d2-checkout-page--cart .button.wc-forward:not(.checkout-button):hover {
    border-color: var(--d2-ink, #222) !important;
    color: var(--d2-ink, #222) !important;
    background: transparent !important;
}

/* "Opdatér kurv" + "Apply coupon" — ghost-dark */
body.d2-checkout-page--cart button[name="apply_coupon"],
body.d2-checkout-page--cart button[name="update_cart"],
body.d2-checkout-page--cart .actions button.button {
    background: transparent !important;
    color: var(--d2-ink, #222) !important;
    border: 1.5px solid var(--d2-line-strong, #d8d8d8) !important;
    padding: 10px 18px !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    line-height: 1 !important;
    border-radius: var(--d2-radius-md, 6px) !important;
    box-shadow: none !important;
    text-shadow: none !important;
    cursor: pointer;
    width: auto !important;
}

body.d2-checkout-page--cart button[name="apply_coupon"]:hover,
body.d2-checkout-page--cart button[name="update_cart"]:hover,
body.d2-checkout-page--cart .actions button.button:hover {
    border-color: var(--d2-ink, #222) !important;
    color: var(--d2-ink, #222) !important;
    background: transparent !important;
}

body.d2-checkout-page--cart button[name="update_cart"]:disabled,
body.d2-checkout-page--cart button[name="update_cart"]:disabled:hover {
    opacity: 0.4 !important;
    cursor: not-allowed !important;
    border-color: var(--d2-line-strong, #d8d8d8) !important;
    color: var(--d2-ink-faint, #666) !important;
}

/* Empty cart "Return to shop" button — primary orange */
body.d2-checkout-page--cart .return-to-shop .wc-backward,
body.d2-checkout-page--cart a.wc-backward {
    background: var(--d2-orange, #fc8902) !important;
    color: #fff !important;
    border: 1.5px solid var(--d2-orange, #fc8902) !important;
    padding: 14px 28px !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    border-radius: var(--d2-radius-md, 6px) !important;
    text-decoration: none !important;
    text-shadow: none !important;
    box-shadow: none !important;
}

body.d2-checkout-page--cart .return-to-shop .wc-backward:hover {
    background: var(--d2-orange-hover, #e57a00) !important;
    border-color: var(--d2-orange-hover, #e57a00) !important;
    color: #fff !important;
}

/* Cart actions row layout — flexbox justeret */
body.d2-checkout-page--cart .woocommerce-cart-form table.shop_table tbody .actions {
    background: var(--d2-surface-alt, #f7f7f7) !important;
    padding: 20px 28px !important;
    border-top: 1px solid var(--d2-line, #e8e8e8) !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
}

/* Sikre at order-total beløb forbliver D2-styled */
body.d2-checkout-page--cart .cart_totals .order-total th,
body.d2-checkout-page--cart .cart_totals .order-total td,
body.d2-checkout-page--cart .cart_totals .order-total .amount {
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 800 !important;
    color: var(--d2-ink, #222) !important;
}

/* ========================================
   CART ACTIONS — robust footer-layout
   
   Sikrer at .actions altid renderes som en grå footer
   med Continue Shopping (venstre) + Update cart (højre)
   uanset om WC placerer den inde i tabel eller udenfor.
   ======================================== */

/* Container fix — fjerner default padding/border på tabel-cellen så .actions
   kan ligne en footer */
body.d2-checkout-page--cart .woocommerce-cart-form table.shop_table tr:has(td.actions),
body.d2-checkout-page--cart .woocommerce-cart-form table.shop_table tr.actions-row {
    background: transparent !important;
}

/* .actions selv — full-width footer */
body.d2-checkout-page--cart td.actions,
body.d2-checkout-page--cart .woocommerce-cart-form td.actions,
body.d2-checkout-page--cart table.shop_table td.actions {
    background: var(--d2-surface-alt, #f7f7f7) !important;
    padding: 18px 28px !important;
    border-top: 1px solid var(--d2-line, #e8e8e8) !important;
    border-bottom: none !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
}

/* Continue shopping link (injiceres via JS) */
.d2cc-continue-shopping {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    color: var(--d2-ink-muted, #444) !important;
    text-decoration: none !important;
    transition: color 0.15s !important;
    padding: 8px 0 !important;
    background: transparent !important;
    border: none !important;
}

.d2cc-continue-shopping:hover {
    color: var(--d2-orange, #fc8902) !important;
}

.d2cc-continue-shopping::before {
    content: "←";
    font-size: 16px;
    line-height: 1;
}

/* Sikre at Update cart-knappen ligger til højre når den står alene */
body.d2-checkout-page--cart td.actions button[name="update_cart"] {
    margin-left: auto !important;
}

/* Når både coupon og update_cart er aktive — coupon venstre, update højre */
body.d2-checkout-page--cart td.actions .coupon {
    margin-right: auto !important;
}

/* Mobile responsive */
@media (max-width: 720px) {
    body.d2-checkout-page--cart td.actions {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
    }
    body.d2-checkout-page--cart td.actions button[name="update_cart"] {
        margin-left: 0 !important;
        width: 100% !important;
    }
    .d2cc-continue-shopping {
        justify-content: center !important;
    }
}

/* ========================================
   D2CC ACTIONS BAR (v1.0.3+)
   
   Erstatning for td.actions — fri bredde, korrekt footer.
   Bar'en bygges i JS efter table.shop_table, inden i form.
   ======================================== */

body.d2-checkout-page--cart .d2cc-actions-bar {
    background: var(--d2-surface-alt, #f7f7f7) !important;
    padding: 18px 28px !important;
    border-top: 1px solid var(--d2-line, #e8e8e8) !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
}

/* Continue shopping — venstre */
body.d2-checkout-page--cart .d2cc-actions-bar .d2cc-continue-shopping {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    color: var(--d2-ink-muted, #444) !important;
    text-decoration: none !important;
    background: transparent !important;
    border: none !important;
    padding: 8px 0 !important;
    margin: 0 !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar .d2cc-continue-shopping:hover {
    color: var(--d2-orange, #fc8902) !important;
}

/* Coupon form — midten (kun hvis aktiveret i WC settings) */
body.d2-checkout-page--cart .d2cc-actions-bar .coupon {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar .coupon label {
    display: none !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar .coupon input[name="coupon_code"] {
    padding: 10px 14px !important;
    background: var(--d2-surface, #fff) !important;
    border: 1px solid var(--d2-line-strong, #d8d8d8) !important;
    border-radius: var(--d2-radius-md, 6px) !important;
    font-family: var(--d2-font-body, Arial, sans-serif) !important;
    font-size: 14px !important;
    color: var(--d2-ink-body, #292929) !important;
    width: 180px !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar .coupon input[name="coupon_code"]:focus {
    outline: none !important;
    border-color: var(--d2-orange, #fc8902) !important;
    box-shadow: 0 0 0 3px rgba(252, 137, 2, 0.15) !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar .coupon button[name="apply_coupon"] {
    padding: 10px 16px !important;
    background: transparent !important;
    color: var(--d2-ink, #222) !important;
    border: 1.5px solid var(--d2-line-strong, #d8d8d8) !important;
    border-radius: var(--d2-radius-md, 6px) !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    margin: 0 !important;
    width: auto !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar .coupon button[name="apply_coupon"]:hover {
    border-color: var(--d2-ink, #222) !important;
    color: var(--d2-ink, #222) !important;
}

/* Update cart button — højre */
body.d2-checkout-page--cart .d2cc-actions-bar button[name="update_cart"],
body.d2-checkout-page--cart .d2cc-actions-bar input[name="update_cart"] {
    margin-left: auto !important;
    padding: 10px 18px !important;
    background: transparent !important;
    color: var(--d2-ink, #222) !important;
    border: 1.5px solid var(--d2-line-strong, #d8d8d8) !important;
    border-radius: var(--d2-radius-md, 6px) !important;
    font-family: var(--d2-font-display, 'Montserrat', sans-serif) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    width: auto !important;
    box-shadow: none !important;
    text-shadow: none !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar button[name="update_cart"]:hover,
body.d2-checkout-page--cart .d2cc-actions-bar input[name="update_cart"]:hover {
    border-color: var(--d2-ink, #222) !important;
    color: var(--d2-ink, #222) !important;
}

body.d2-checkout-page--cart .d2cc-actions-bar button[name="update_cart"]:disabled,
body.d2-checkout-page--cart .d2cc-actions-bar input[name="update_cart"]:disabled {
    opacity: 0.4 !important;
    cursor: not-allowed !important;
}

/* Mobile responsive */
@media (max-width: 720px) {
    body.d2-checkout-page--cart .d2cc-actions-bar {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
    }
    body.d2-checkout-page--cart .d2cc-actions-bar .d2cc-continue-shopping {
        justify-content: center !important;
        text-align: center !important;
    }
    body.d2-checkout-page--cart .d2cc-actions-bar .coupon {
        flex-direction: column !important;
    }
    body.d2-checkout-page--cart .d2cc-actions-bar .coupon input[name="coupon_code"],
    body.d2-checkout-page--cart .d2cc-actions-bar .coupon button[name="apply_coupon"],
    body.d2-checkout-page--cart .d2cc-actions-bar button[name="update_cart"] {
        width: 100% !important;
        margin: 0 !important;
    }
}
