/* =====================================================================
 * MasnoonHub Express — v7 Checkout (assets/woo-checkout.css)
 * Ports board "Cart & Checkout.html" (.dcheck) onto WooCommerce checkout.
 * Everything is scoped under .mh-checkout (set by
 * woocommerce/checkout/form-checkout.php); the full-width block is scoped to
 * body.woocommerce-checkout. Colours/type from tokens.css. Layout is fluid
 * (flex / clamp / minmax) so it never overlaps at intermediate widths.
 *
 * Sections:
 *   0  Astra full-width neutralisation (boxed page + left sidebar + title)
 *   1  Wrapper + step bar (.dkcheck)
 *   2  Two-column grid (.dcheck) + step cards (.formcard)
 *   3  Card 1 — billing fields (WooCommerce output → board look)
 *   4  Card 2 — delivery method (.delivopt)
 *   5  Card 3 — payment (.paywrap / .payopt + COD + placeholders)
 *   6  Card 4 — review (.reviewbox / .rmini / .assure)
 *   7  Rail — summary (.drail / .sumcard / totals) + Place Order + charity
 *   8  Guarantee box (.guarbox)
 *   9  Price-amount colour guard (beats woo.css #content paint)
 *   10 Responsive
 * ===================================================================== */

/* ---- 0. Astra full-width neutralisation (scoped to checkout body) ---- */
.woocommerce-checkout #secondary{ display:none !important; width:0 !important; height:0 !important; overflow:hidden !important; }
.woocommerce-checkout #primary{ width:100% !important; max-width:100% !important; padding-top:0 !important; }
.woocommerce-checkout .ast-container{ display:block !important; max-width:1240px !important; }
.woocommerce-checkout .entry-header,
.woocommerce-checkout .page-title,
.woocommerce-checkout .ast-archive-description,
.woocommerce-checkout .woocommerce-breadcrumb{ display:none !important; }
.woocommerce-checkout .site-content,
.woocommerce-checkout #content,
.woocommerce-checkout #content > .ast-container,
.woocommerce-checkout #main,
.woocommerce-checkout #primary{ padding-top:0 !important; margin-top:0 !important; }
body.woocommerce-checkout #content .ast-article-single{ margin:5px 0 0 !important; padding:0 !important; border:0 !important; border-radius:0 !important; background:#fff !important; box-shadow:none !important; }
/* Default WC checkout chrome we replace */
.mh-checkout #order_review_heading,
.mh-checkout .woocommerce-billing-fields > h3,
.mh-checkout .woocommerce-shipping-fields,
.mh-checkout .woocommerce-additional-fields,
.mh-checkout #ship-to-different-address,
.mh-checkout .optional{ display:none !important; }

/* ---- 1. Wrapper + step bar ---- */
.mh-checkout{ max-width:1240px; margin:0 auto; padding:0; color:var(--ink); font-family:var(--font-body); line-height:1.5; }
.mh-checkout *{ box-sizing:border-box; }

.mh-checkout .dkcheck{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; padding:16px clamp(16px,3vw,24px); background:#fff; border-bottom:1px solid var(--line-2); }
.mh-checkout .dkcheck h2{ font-family:var(--font-display); font-weight:700; font-size:clamp(20px,2.4vw,24px); margin:0; letter-spacing:-.01em; color:var(--ink); }
.mh-checkout .dkcheck h2 em{ font-style:italic; color:var(--brand); font-weight:600; }
.mh-checkout .dsteps{ display:flex; align-items:center; gap:10px; margin-left:auto; flex-wrap:wrap; }
.mh-checkout .dstep{ display:flex; align-items:center; gap:8px; font-size:12.5px; font-weight:700; color:var(--ink-3); letter-spacing:.04em; text-transform:uppercase; }
.mh-checkout .dstep .n{ width:22px; height:22px; border-radius:50%; background:var(--app-bg); color:var(--ink-3); display:grid; place-items:center; font-size:11px; font-weight:800; }
.mh-checkout .dstep .n svg{ width:11px; height:11px; }
.mh-checkout .dstep.on{ color:var(--ink); }
.mh-checkout .dstep.on .n{ background:var(--brand); color:#fff; }
.mh-checkout .dstep.done .n{ background:var(--green); color:#fff; }
.mh-checkout .dstep.done{ color:var(--green-ink); }
.mh-checkout .dbar{ width:34px; height:2px; background:var(--app-bg); border-radius:2px; }
.mh-checkout .dbar.done{ background:var(--green); }
.mh-checkout .dsecure{ display:flex; align-items:center; gap:6px; font-size:12px; color:var(--green-ink); background:var(--green-soft); border:1px solid color-mix(in srgb,var(--green) 25%,transparent); padding:6px 11px; border-radius:var(--r-pill); font-weight:700; }
.mh-checkout .dsecure svg{ width:13px; height:13px; color:var(--green); }

/* ---- 2. Two-column grid + step cards ---- */
.mh-checkout .dcheck{ display:grid; grid-template-columns:minmax(0,1fr) minmax(300px,360px); gap:22px; padding:clamp(14px,2.4vw,22px) clamp(16px,3vw,24px) clamp(28px,4vw,40px); align-items:start; }
.mh-checkout .ccol-main{ min-width:0; }
.mh-checkout .formcard{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:clamp(15px,2vw,20px); }
.mh-checkout .formcard + .formcard{ margin-top:14px; }
.mh-checkout .formcard > h3{ font-family:var(--font-display); font-weight:700; font-size:18px; margin:0 0 13px; display:flex; align-items:center; gap:9px; color:var(--ink); }
.mh-checkout .formcard > h3 .num{ width:24px; height:24px; flex:none; border-radius:50%; background:var(--navy); color:#fff; font-family:var(--font-body); font-size:11px; font-weight:800; display:grid; place-items:center; }

/* ---- 3. Card 1 — billing fields (WC output styled to the board) ---- */
.mh-checkout .woocommerce-billing-fields__field-wrapper{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:11px; }
.mh-checkout .form-row{ margin:0 !important; padding:0 !important; width:auto !important; float:none !important; min-width:0; display:flex; flex-direction:column; }
.mh-checkout .form-row-wide{ grid-column:1 / -1; }
.mh-checkout .form-row-first{ grid-column:1 / 2; }
.mh-checkout .form-row-last{ grid-column:2 / 3; }
.mh-checkout #billing_country_field{ display:none !important; }
.mh-checkout .form-row label{ display:block; font-size:11.5px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-2); margin:0 0 5px; }
.mh-checkout .form-row label .required,
.mh-checkout .form-row label abbr.required{ color:var(--brand); border:0; text-decoration:none; }
.mh-checkout .woocommerce-input-wrapper{ display:block; width:100%; }
.mh-checkout .form-row input.input-text,
.mh-checkout .form-row textarea,
.mh-checkout .form-row select{ width:100% !important; height:46px; min-height:46px !important; border:1.5px solid var(--line) !important; border-radius:var(--r-sm) !important; padding:0 13px !important; font-family:var(--font-body); font-size:14px !important; line-height:normal; color:var(--ink) !important; background:#fff !important; outline:none; box-shadow:none !important; transition:border-color .15s, box-shadow .15s; }
.mh-checkout .form-row textarea{ height:auto; min-height:78px !important; padding:11px 13px !important; resize:vertical; }
.mh-checkout .form-row input.input-text:focus,
.mh-checkout .form-row textarea:focus,
.mh-checkout .form-row select:focus{ border-color:var(--brand) !important; box-shadow:0 0 0 3px var(--brand-soft) !important; }
/* District dropdown: native select, custom chevron so it reads like the inputs. */
.mh-checkout .form-row select{ -webkit-appearance:none !important; -moz-appearance:none !important; appearance:none !important; cursor:pointer; padding-right:38px !important; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23141d33' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>") !important; background-repeat:no-repeat !important; background-position:right 12px center !important; background-size:16px !important; }
.mh-checkout .form-row.woocommerce-invalid input.input-text,
.mh-checkout .form-row.woocommerce-invalid textarea{ border-color:var(--red) !important; box-shadow:0 0 0 2px var(--red-soft) !important; }
.mh-checkout .woocommerce-error,
.mh-checkout .woocommerce-message,
.mh-checkout .woocommerce-info{ font-size:13px; border-radius:var(--r-sm); }
/* +880 prefix on the phone field (no custom markup needed) */
.mh-checkout #billing_phone_field .woocommerce-input-wrapper{ position:relative; }
.mh-checkout #billing_phone_field .woocommerce-input-wrapper::before{ content:"🇧🇩 +880"; position:absolute; left:0; top:0; height:46px; display:flex; align-items:center; gap:5px; padding:0 11px; font-size:13.5px; font-weight:700; color:var(--ink); background:var(--app-bg); border-right:1px solid var(--line); border-radius:var(--r-sm) 0 0 var(--r-sm); pointer-events:none; }
.mh-checkout #billing_phone_field input.input-text{ padding-left:82px !important; }
/* Account / order-note stragglers if a plugin re-adds them */
.mh-checkout .woocommerce-account-fields{ margin-top:11px; }

/* ---- 4. Card 2 — delivery method ---- */
.mh-checkout .mh-frag-delivery{ display:flex; flex-direction:column; gap:9px; }
.mh-checkout .delivopt{ display:flex; align-items:center; gap:12px; border:1.5px solid var(--line); background:#fff; border-radius:var(--r-md); padding:12px 13px; cursor:pointer; position:relative; }
.mh-checkout .delivopt input{ position:absolute; opacity:0; width:1px; height:1px; pointer-events:none; }
.mh-checkout .delivopt.on{ border-color:var(--brand); background:var(--brand-soft); box-shadow:inset 0 0 0 1px var(--brand); }
.mh-checkout .delivopt .dic{ width:38px; height:38px; flex:none; border-radius:10px; background:var(--app-bg); display:grid; place-items:center; color:var(--navy); }
.mh-checkout .delivopt.on .dic{ background:#fff; color:var(--brand); }
.mh-checkout .delivopt .dic svg{ width:20px; height:20px; }
.mh-checkout .delivopt .dbody{ flex:1 1 auto; min-width:0; }
.mh-checkout .delivopt .dt{ font-weight:700; font-size:13.5px; color:var(--ink); }
.mh-checkout .delivopt .dsub{ font-size:11.5px; color:var(--ink-3); margin-top:2px; }
.mh-checkout .delivopt .dcost{ flex:none; font-weight:800; font-size:14px; color:var(--ink); font-variant-numeric:tabular-nums; }
.mh-checkout .delivopt .dcost.free{ color:var(--green); text-transform:uppercase; font-size:11.5px; letter-spacing:.04em; }
.mh-checkout .delivopt .radio{ width:18px; height:18px; flex:none; border-radius:50%; border:1.5px solid var(--line); position:relative; }
.mh-checkout .delivopt.on .radio{ border-color:var(--brand); }
.mh-checkout .delivopt.on .radio::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--brand); }
.mh-checkout .delivnote{ font-size:12.5px; color:var(--ink-3); padding:10px 2px; }
.mh-checkout .delivvendor{ display:flex; align-items:center; gap:7px; font-size:11px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); margin:8px 1px 1px; }
.mh-checkout .delivvendor:first-child{ margin-top:0; }
.mh-checkout .delivvendor .vd{ width:6px; height:6px; border-radius:50%; background:var(--brand); flex:none; }

/* ---- 5. Card 3 — payment ---- */
.mh-checkout #payment{ background:transparent !important; border:0 !important; border-radius:0 !important; padding:0 !important; }
.mh-checkout .paywrap{ display:flex; flex-direction:column; gap:10px; list-style:none; margin:0; padding:0; }
.mh-checkout .payopt{ list-style:none; margin:0; border:1.5px solid var(--line); background:#fff; border-radius:var(--r-md); position:relative; }
.mh-checkout .payopt .payopt-row{ display:flex; align-items:center; gap:12px; padding:12px 13px; cursor:pointer; }
.mh-checkout .payopt input.input-radio{ position:absolute; opacity:0; width:1px; height:1px; pointer-events:none; }
.mh-checkout .payopt.on{ border-color:var(--brand); background:var(--brand-soft); box-shadow:inset 0 0 0 1px var(--brand); }
.mh-checkout .payopt .plogo{ width:46px; height:38px; flex:none; border-radius:8px; display:grid; place-items:center; background:#fff; border:1px solid var(--line); font-weight:800; color:#fff; font-size:11px; letter-spacing:.02em; overflow:hidden; }
.mh-checkout .payopt.cod .plogo{ background:var(--navy); border-color:var(--navy); }
.mh-checkout .payopt.cod .plogo svg{ color:#fff; width:22px; height:22px; }
.mh-checkout .payopt.bk .plogo{ background:var(--bkash); border-color:var(--bkash); font-size:12px; font-family:var(--font-display); font-style:italic; font-weight:800; letter-spacing:-.02em; }
.mh-checkout .payopt.ng .plogo{ background:var(--nagad); border-color:var(--nagad); font-size:11.5px; font-family:var(--font-display); font-weight:800; }
.mh-checkout .payopt.cc .plogo{ background:#fff; color:var(--ink); display:flex; align-items:center; justify-content:center; gap:3px; padding:0 4px; }
.mh-checkout .payopt.cc .plogo small{ font-size:9px; font-weight:800; padding:2px 4px; border-radius:3px; line-height:1; }
.mh-checkout .payopt.cc .plogo .visa{ background:#1a1f71; color:#fff; }
.mh-checkout .payopt.cc .plogo .mc{ background:#eb001b; color:#fff; }
.mh-checkout .payopt .pbody{ flex:1 1 auto; min-width:0; }
.mh-checkout .payopt .pn{ font-weight:700; font-size:14px; color:var(--ink); display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.mh-checkout .payopt .pn small{ font-weight:800; font-size:10px; letter-spacing:.06em; text-transform:uppercase; background:var(--brand); color:#fff; padding:2px 6px; border-radius:4px; }
.mh-checkout .payopt .pn small.soon{ background:var(--app-bg); color:var(--ink-3); }
.mh-checkout .payopt .ps{ font-size:11.5px; color:var(--ink-3); margin-top:2px; line-height:1.35; }
.mh-checkout .payopt .radio{ width:18px; height:18px; flex:none; border-radius:50%; border:1.5px solid var(--line); position:relative; align-self:center; }
.mh-checkout .payopt.on .radio{ border-color:var(--brand); }
.mh-checkout .payopt.on .radio::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--brand); }
/* COD rich treatment */
.mh-checkout .payopt.cod{ display:block; }
.mh-checkout .payopt.cod.on{ border-color:var(--brand); background:linear-gradient(180deg,#fff8f3,var(--brand-soft) 90%); box-shadow:inset 0 0 0 1px var(--brand), 0 4px 14px -8px rgba(224,83,15,.45); }
.mh-checkout .payopt.cod .pextra{ font-size:11.5px; color:var(--brand-ink); margin:0 13px 12px; padding-top:8px; border-top:1px dashed color-mix(in srgb,var(--brand) 30%,transparent); display:none; }
.mh-checkout .payopt.cod.on .pextra{ display:block; }
.mh-checkout .payopt.cod .pextra b{ color:var(--brand-ink); font-weight:800; }
/* coming-soon placeholders (li with direct flex, no label) */
.mh-checkout .payopt.mh-soon{ display:flex; align-items:center; gap:12px; padding:12px 13px; opacity:.62; pointer-events:none; }
/* gateway payment box (bKash/Nagad/Card when real) */
.mh-checkout .payopt .payment_box{ margin:0 13px 12px; font-size:12.5px; color:var(--ink-2); }
.mh-checkout .payopt .payment_box p:first-child{ margin-top:0; }
/* shared note */
.mh-checkout .paynote{ font-size:11.5px; color:var(--ink-3); margin-top:10px; display:flex; align-items:center; gap:6px; line-height:1.4; }
.mh-checkout .paynote svg{ width:13px; height:13px; flex:none; color:var(--trust); }

/* ---- 6. Card 4 — review ---- */
.mh-checkout .reviewbox{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; }
.mh-checkout .rvbody{ padding:4px 13px 0; display:flex; flex-direction:column; }
.mh-checkout .rmini{ display:grid; grid-template-columns:42px minmax(0,1fr) auto; gap:11px; align-items:center; padding:9px 0; border-top:1px dashed var(--line); }
.mh-checkout .rmini:first-child{ border-top:0; }
.mh-checkout .rmini .tt{ width:42px; height:42px; border-radius:8px; overflow:hidden; background:linear-gradient(125deg,var(--accent-soft) 0 46%,color-mix(in srgb,var(--accent-soft) 38%,#fff) 46%); padding:4px; position:relative; }
.mh-checkout .rmini .tt img{ width:100%; height:100%; object-fit:contain; display:block; }
.mh-checkout .rmini .tt.ph{ background:repeating-linear-gradient(135deg,var(--accent-soft) 0 7px,#fff 7px 14px); }
.mh-checkout .rmini .tt .qbadge{ position:absolute; top:-5px; right:-5px; background:var(--navy); color:#fff; font-size:9.5px; font-weight:800; min-width:17px; height:17px; border-radius:9px; display:grid; place-items:center; padding:0 4px; border:1.5px solid #fff; }
.mh-checkout .rmini .rmi{ min-width:0; }
.mh-checkout .rmini .rmt{ font-size:12.5px; font-weight:600; color:var(--ink); line-height:1.3; display:-webkit-box; -webkit-line-clamp:1; line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
.mh-checkout .rmini .rmv{ font-size:11px; color:var(--ink-3); margin-top:1px; }
.mh-checkout .rmini .rmp{ font-weight:800; font-size:13px; color:var(--ink); font-variant-numeric:tabular-nums; white-space:nowrap; text-align:right; }
.mh-checkout .rmini .rmp .rmx{ font-size:10px; font-weight:600; color:var(--ink-3); }
.mh-checkout .assure{ background:var(--trust-soft); border-top:1px solid color-mix(in srgb,var(--trust) 20%,var(--line)); padding:11px 13px; display:flex; align-items:center; gap:10px; margin-top:10px; }
.mh-checkout .assure .seal{ width:30px; height:30px; flex:none; border-radius:50%; background:radial-gradient(circle at 32% 28%,#5b9bd6,var(--trust) 70%); display:grid; place-items:center; box-shadow:0 4px 10px -4px rgba(47,111,176,.5), inset 0 0 0 2px rgba(255,255,255,.3); }
.mh-checkout .assure .seal svg{ width:15px; height:15px; color:#fff; }
.mh-checkout .assure .at{ font-size:12px; color:var(--navy); font-weight:700; line-height:1.35; }
.mh-checkout .assure .at em{ font-style:normal; color:var(--trust); }

/* ---- 7. Rail ---- */
.mh-checkout .drail{ position:sticky; top:14px; display:flex; flex-direction:column; gap:14px; min-width:0; }
.mh-checkout .sumcard{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:16px 18px; box-shadow:var(--shadow-sm); }
.mh-checkout .sumcard h4{ font-family:var(--font-display); font-weight:700; font-size:16px; margin:0 0 12px; color:var(--ink); }
.mh-checkout .sumrow{ display:flex; justify-content:space-between; align-items:center; font-size:13px; padding:5px 0; color:var(--ink-2); gap:12px; }
.mh-checkout .sumrow b{ color:var(--ink); font-weight:700; font-variant-numeric:tabular-nums; white-space:nowrap; }
.mh-checkout .sumrow.disc b{ color:var(--green); }
.mh-checkout .sumrow.free b{ color:var(--green); text-transform:uppercase; font-size:11.5px; letter-spacing:.04em; }
.mh-checkout .sumtot{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; margin-top:9px; padding-top:11px; border-top:1px solid var(--line); }
.mh-checkout .sumtot .lab{ font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--ink); }
.mh-checkout .sumtot .lab small{ display:block; font-family:var(--font-body); font-size:10.5px; color:var(--ink-3); font-weight:600; letter-spacing:.04em; text-transform:uppercase; margin-top:2px; }
.mh-checkout .sumtot .tot{ font-size:24px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; letter-spacing:-.01em; white-space:nowrap; }
.mh-checkout .divider{ height:1px; background:var(--line-2); margin:13px 0; }

/* Place Order — green confirm button */
.mh-checkout .place-order{ margin:0 !important; padding:0 !important; }
.mh-checkout .woocommerce-terms-and-conditions-wrapper{ font-size:12px; color:var(--ink-2); margin-bottom:11px; }
.mh-checkout .cbtn{ display:flex; align-items:center; justify-content:center; gap:8px; border:0; border-radius:13px; font-family:var(--font-body); font-weight:800; font-size:14.5px; cursor:pointer; text-decoration:none; }
.mh-checkout .cbtn svg{ width:18px; height:18px; }
.mh-checkout .cbtn.full{ width:100%; }
.mh-checkout .cbtn.co-place{ height:50px !important; background:linear-gradient(180deg,#3fbf83,var(--green)) !important; color:#fff !important; box-shadow:0 6px 16px -6px rgba(29,138,92,.5); padding:0 22px; }
.mh-checkout .cbtn.co-place:hover{ filter:brightness(1.03); }
.mh-checkout .cbtn.co-place:disabled{ opacity:.6; cursor:default; }

/* charity (quiet) */
.mh-checkout .charity.quiet{ display:flex; gap:10px; align-items:flex-start; background:transparent; border:0; padding:11px 2px 2px; margin-top:6px; }
.mh-checkout .charity.quiet .cic{ width:30px; height:30px; flex:none; border-radius:50%; background:var(--charity-soft); display:grid; place-items:center; color:var(--charity); }
.mh-checkout .charity.quiet .cic svg{ width:16px; height:16px; }
.mh-checkout .charity.quiet .cb{ flex:1; min-width:0; }
.mh-checkout .charity.quiet .ct{ font-size:13px; font-weight:700; color:var(--charity-ink); line-height:1.3; }
.mh-checkout .charity.quiet .cd{ font-size:11.5px; color:var(--charity-ink); opacity:.88; margin-top:2px; line-height:1.45; }
.mh-checkout .charity.quiet .cd b{ font-weight:800; opacity:1; }

/* ---- 8. Guarantee box ---- */
.mh-checkout .guarbox{ display:flex; align-items:flex-start; gap:11px; padding:12px 14px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); }
.mh-checkout .guarbox .gic{ width:36px; height:36px; flex:none; border-radius:10px; background:var(--green-soft); display:grid; place-items:center; color:var(--green); }
.mh-checkout .guarbox .gic svg{ width:19px; height:19px; }
.mh-checkout .guarbox .gt{ font-weight:700; font-size:13.5px; color:var(--ink); line-height:1.3; }
.mh-checkout .guarbox .gs{ font-size:12px; color:var(--ink-2); margin-top:3px; line-height:1.45; }

/* ---- 9. Price-amount colour guard (beats woo.css #content paint) ---- */
.mh-checkout .woocommerce-Price-amount{ color:inherit !important; }
.mh-checkout .delivopt .dcost{ color:var(--ink); }
.mh-checkout .delivopt .dcost.free{ color:var(--green); }
.mh-checkout .sumrow b{ color:var(--ink); }
.mh-checkout .sumrow.disc b{ color:var(--green); }
.mh-checkout .sumtot .tot{ color:var(--ink); }
.mh-checkout .rmini .rmp{ color:var(--ink); }
.mh-checkout .payopt.cod .pextra{ color:var(--brand-ink); }

/* ---- 10. Responsive ---- */
@media (max-width:1024px){
	.mh-checkout .dcheck{ grid-template-columns:1fr; }
	.mh-checkout .drail{ position:static; }
}
@media (max-width:560px){
	.mh-checkout .dkcheck{ gap:10px 14px; padding:13px 14px; }
	.mh-checkout .dkcheck h2{ font-size:19px; width:100%; }
	.mh-checkout .dsteps{ margin-left:0; gap:7px; }
	.mh-checkout .dbar{ width:18px; }
	.mh-checkout .dstep{ font-size:11px; }
	.mh-checkout .dcheck{ padding:12px 13px 26px; gap:14px; }
	.mh-checkout .formcard{ padding:14px; }
	.mh-checkout .woocommerce-billing-fields__field-wrapper{ gap:10px; }
	.mh-checkout .sumtot .tot{ font-size:22px; }
}

/* ---- 11. Available coupons (custom panel; replaces the Power Coupons drawer) ---- */
/* Hide the broken Power Coupons drawer + its trigger — our own list takes over. */
.power-coupons-drawer-trigger-wrapper,
.power-coupons-view-coupons-btn,
.power-coupons-drawer,
.power-coupons-drawer-overlay{ display:none !important; }

.mh-checkout .mh-coupons{ margin:0 0 13px; }
.mh-checkout .mh-coupons__toggle{ width:100%; display:flex; align-items:center; gap:9px; background:#fff; border:1.5px dashed var(--brand); color:var(--brand-ink); border-radius:var(--r-md); padding:11px 13px; font-family:var(--font-body); font-weight:700; font-size:13.5px; cursor:pointer; }
.mh-checkout .mh-coupons__toggle svg{ width:17px; height:17px; flex:none; color:var(--brand); }
.mh-checkout .mh-coupons__toggle span{ flex:1; text-align:left; }
.mh-checkout .mh-coupons__toggle .chev{ transition:transform .18s ease; }
.mh-checkout .mh-coupons__toggle[aria-expanded="true"] .chev{ transform:rotate(180deg); }
.mh-checkout .mh-coupons__panel{ margin-top:10px; display:flex; flex-direction:column; gap:10px; }
.mh-checkout .mh-coupons__panel[hidden]{ display:none; }
.mh-checkout .mh-coupons__manual{ display:flex; gap:8px; }
.mh-checkout .mh-coupon-input{ flex:1; min-width:0; height:44px; border:1.5px solid var(--line); border-radius:var(--r-sm); padding:0 13px; font-family:var(--font-body); font-size:14px; color:var(--ink); background:#fff; outline:none; }
.mh-checkout .mh-coupon-input:focus{ border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-soft); }
.mh-checkout .mh-coupon-apply{ flex:none; border:0; border-radius:var(--r-sm); background:linear-gradient(180deg,var(--brand-bright,#f4732e),var(--brand)); color:#fff; font-family:var(--font-body); font-weight:800; font-size:13px; padding:0 18px; height:44px; cursor:pointer; }
.mh-checkout .mh-coupon-apply:disabled{ opacity:.5; cursor:default; }
.mh-checkout .mh-coupon{ display:flex; align-items:center; gap:11px; justify-content:space-between; border:1.5px dashed var(--line); border-radius:var(--r-sm); padding:10px 12px; background:var(--app-bg); }
.mh-checkout .mh-coupon.is-applied{ border-style:solid; border-color:var(--green); background:var(--green-soft,#eafaf2); }
.mh-checkout .mh-coupon__info{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.mh-checkout .mh-coupon__code{ font-weight:800; font-size:13px; letter-spacing:.04em; color:var(--brand-ink); }
.mh-checkout .mh-coupon__benefit{ font-weight:700; font-size:12px; color:var(--ink); }
.mh-checkout .mh-coupon__desc{ font-size:11px; color:var(--ink-3); line-height:1.4; }
.mh-checkout .mh-coupon .mh-coupon-apply{ height:34px; padding:0 14px; font-size:12px; }
.mh-checkout .mh-coupons__msg{ font-size:12px; line-height:1.4; }
.mh-checkout .mh-coupons__msg:empty{ display:none; }
.mh-checkout .mh-coupons__msg .woocommerce-message,
.mh-checkout .mh-coupons__msg .woocommerce-error,
.mh-checkout .mh-coupons__msg .woocommerce-info{ margin:0; padding:9px 12px; border-radius:var(--r-sm); font-size:12px; list-style:none; border:0; }
.mh-checkout .mh-coupons__empty{ font-size:12px; color:var(--ink-3); }

/* ---- 12. Order received / thank-you (.mh-thankyou) ---- */
/* full-width neutralisation for the order-received endpoint (mirrors §0) */
.woocommerce-order-received #secondary{ display:none !important; width:0 !important; height:0 !important; overflow:hidden !important; }
.woocommerce-order-received #primary{ width:100% !important; max-width:100% !important; padding-top:0 !important; }
.woocommerce-order-received .ast-container{ display:block !important; max-width:1240px !important; }
.woocommerce-order-received .entry-header,
.woocommerce-order-received .page-title,
.woocommerce-order-received .ast-archive-description,
.woocommerce-order-received .woocommerce-breadcrumb{ display:none !important; }
.woocommerce-order-received .site-content,
.woocommerce-order-received #content,
.woocommerce-order-received #main,
.woocommerce-order-received #primary{ padding-top:0 !important; margin-top:0 !important; }
body.woocommerce-order-received #content .ast-article-single{ margin:5px 0 0 !important; padding:0 !important; border:0 !important; border-radius:0 !important; background:#fff !important; box-shadow:none !important; }

.mh-thankyou .ty-wrap{ max-width:600px; margin:0 auto; padding:clamp(18px,3vw,30px) clamp(16px,3vw,24px) 40px; display:flex; flex-direction:column; gap:15px; }
.mh-thankyou .ty-hero{ text-align:center; padding:8px 0 2px; }
.mh-thankyou .ty-ic{ width:62px; height:62px; border-radius:50%; background:var(--green-soft); color:var(--green); display:grid; place-items:center; margin:0 auto 14px; box-shadow:0 10px 24px -10px color-mix(in srgb,var(--green) 65%,transparent); }
.mh-thankyou .ty-ic svg{ width:30px; height:30px; }
.mh-thankyou .ty-hero.is-fail .ty-ic{ background:var(--red-soft); color:var(--red); box-shadow:none; }
.mh-thankyou .ty-kf{ display:block; font-size:11.5px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.mh-thankyou .ty-hero.is-fail .ty-kf{ color:var(--red); }
.mh-thankyou .ty-hero h3{ font-family:var(--font-display); font-weight:700; font-size:clamp(22px,3.2vw,28px); margin:8px 0 7px; line-height:1.15; letter-spacing:-.01em; color:var(--ink); }
.mh-thankyou .ty-hero p{ margin:0 auto; max-width:44ch; font-size:14px; color:var(--ink-2); line-height:1.6; }
.mh-thankyou .ty-badge{ display:inline-flex; align-items:center; gap:5px; padding:2px 9px; border-radius:999px; font-size:11px; font-weight:800; letter-spacing:.02em; vertical-align:middle; }
.mh-thankyou .ty-badge.cod{ background:var(--green-soft); color:var(--green-ink); }
/* receipt (dashed ticket) */
.mh-thankyou .receipt{ background:#fff; border:1.5px dashed var(--line); border-radius:var(--r-md); padding:15px 18px; }
.mh-thankyou .receipt h4{ margin:0 0 10px; font-family:var(--font-display); font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-3); }
.mh-thankyou .receipt .row{ display:flex; justify-content:space-between; gap:12px; padding:5px 0; font-size:13px; color:var(--ink-2); }
.mh-thankyou .receipt .row b{ color:var(--ink); font-weight:600; font-variant-numeric:tabular-nums; white-space:nowrap; }
.mh-thankyou .receipt .row.item{ color:var(--ink); }
.mh-thankyou .receipt .row.item .qx{ color:var(--ink-3); font-size:11px; }
.mh-thankyou .receipt .row b.free{ color:var(--green); text-transform:uppercase; font-size:11.5px; letter-spacing:.04em; }
.mh-thankyou .receipt .row b.disc{ color:var(--green); }
.mh-thankyou .receipt .row.is-grand{ border-top:1px dashed var(--line); padding-top:11px; margin-top:5px; font-family:var(--font-display); font-weight:700; font-size:16px; }
.mh-thankyou .receipt .row.is-grand span{ color:var(--ink); }
.mh-thankyou .receipt .row.is-grand b{ color:var(--brand); font-size:18px; }
/* charity impact */
.mh-thankyou .impact{ background:linear-gradient(135deg,#fdf2dc,#fff); border:1px solid #ecc88c; padding:13px 14px; border-radius:var(--r-md); display:flex; align-items:flex-start; gap:11px; }
.mh-thankyou .impact .ic{ width:34px; height:34px; border-radius:10px; background:#a07210; color:#fff; display:grid; place-items:center; flex:none; }
.mh-thankyou .impact .ic svg{ width:18px; height:18px; }
.mh-thankyou .impact b{ display:block; font-size:13px; color:#7e5807; font-weight:800; }
.mh-thankyou .impact span{ display:block; font-size:11.5px; color:#7e5807; margin-top:1px; line-height:1.45; }
/* what happens next */
.mh-thankyou .ty-next{ background:linear-gradient(135deg,var(--green-soft),#fff); border:1px solid #bde0cd; border-radius:var(--r-md); padding:13px 16px; }
.mh-thankyou .ty-next b{ display:block; font-size:13px; color:#0c3a27; font-weight:800; margin-bottom:6px; }
.mh-thankyou .ty-next ul{ margin:0; padding:0 0 0 17px; }
.mh-thankyou .ty-next li{ font-size:12.5px; color:#1f5340; padding:2px 0; line-height:1.5; }
/* CTAs */
.mh-thankyou .ty-cta{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.mh-thankyou .ty-cta .cbtn{ height:48px !important; }
.mh-thankyou .ty-cta .cbtn.ghost{ background:#fff !important; color:var(--ink) !important; border:1.5px solid var(--line) !important; box-shadow:none !important; }
@media (max-width:520px){ .mh-thankyou .ty-cta{ grid-template-columns:1fr; } }

/* Step bar: below desktop, drop the connector dashes so the three steps wrap
   cleanly under the heading instead of leaving a dangling bar after "Checkout". */
@media (max-width:880px){
	.mh-checkout .dkcheck{ flex-direction:column; align-items:flex-start; gap:11px; }
	.mh-checkout .dsteps{ margin-left:0; gap:9px 14px; }
	.mh-checkout .dbar{ display:none; }
}
/* Smallest phones: shrink the chips so all three steps stay on one line. */
@media (max-width:560px){
	.mh-checkout .dsteps{ gap:7px 11px; }
	.mh-checkout .dstep{ font-size:10.5px; gap:6px; letter-spacing:.02em; }
	.mh-checkout .dstep .n{ width:19px; height:19px; font-size:10px; }
}
