/* =====================================================
   MEI BEDDING — cart-checkout.css
   Page hero (small banner), generic page section, card shell, form helpers, cart, checkout, order success, auth, account, order detail, track order.
   Extracted from hifi-v2.css appended sections 27-37.
   ===================================================== */

/* ---------- 27. Page hero (small banner used across content pages) ---------- */
.page-hero {
  background: var(--bone-soft);
  padding: var(--sp-7) 0 var(--sp-6);
  text-align: center;
  border-bottom: 1px solid var(--line);
}
.page-hero h1 {
  font-family: var(--font-serif);
  font-size: 32px;
  font-weight: 400;
  margin-bottom: var(--sp-3);
}
.page-hero p {
  color: var(--ink-soft);
  max-width: 640px;
  margin: 0 auto;
}
@media (min-width: 1024px) {
  .page-hero { padding: var(--sp-8) 0 var(--sp-7); }
  .page-hero h1 { font-size: 40px; }
}

/* ---------- 28. Generic page section ---------- */
.page-section { padding: var(--sp-7) 0; }
@media (min-width: 1024px) { .page-section { padding: var(--sp-8) 0; } }
.page-section h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  margin-bottom: var(--sp-4);
}
.page-section h3 {
  font-size: 16px;
  margin: var(--sp-5) 0 var(--sp-3);
}
.page-section p, .page-section li { color: var(--ink-soft); line-height: 1.7; }
.page-section p { margin-bottom: var(--sp-4); }
.page-section ul { padding-left: var(--sp-5); margin-bottom: var(--sp-4); }
.page-section ul li { list-style: disc; margin-bottom: var(--sp-2); }

/* ---------- 29. Card (generic shell) ---------- */
.card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
}
.card h3 { margin-bottom: var(--sp-3); }
.card + .card { margin-top: var(--sp-4); }

/* ---------- 30. Form layout helpers ---------- */
/* Match hifi: gap label→input = 8px (label has mb 8px, grid gap 0). */
.form-row { display: grid; grid-template-columns: 1fr; gap: 0; margin-bottom: var(--sp-4); }
@media (min-width: 640px) {
  .form-row--2 { grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
}
.form-label { display: block; font-size: 12px; font-weight: 500; margin-bottom: var(--sp-2); color: var(--ink-soft); }
.form-help { font-size: 12px; color: var(--muted); margin-top: var(--sp-2); }
.form-group-title {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
  color: var(--ink);
  margin: var(--sp-5) 0 var(--sp-3);
  padding-bottom: var(--sp-2);
  border-bottom: 1px solid var(--line);
}
.form-group-title:first-child { margin-top: 0; }

/* ---------- 31. Cart ---------- */
.cart-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  padding-bottom: var(--sp-8);
}
@media (min-width: 1024px) {
  .cart-layout { grid-template-columns: 1.6fr 1fr; gap: var(--sp-6); }
}
.cart-table { display: flex; flex-direction: column; gap: var(--sp-3); }
.cart-row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: var(--sp-3);
  padding: var(--sp-4);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  align-items: flex-start;
}
.cart-row-img { width: 80px; height: 80px; border-radius: var(--radius); overflow: hidden; background: var(--bone-soft); }
.cart-row-img img { width: 100%; height: 100%; object-fit: cover; }
.cart-row-info { min-width: 0; }
.cart-row-name { font-size: 14px; font-weight: 600; margin-bottom: var(--sp-1); }
.cart-row-variation { font-size: 12px; color: var(--muted); margin-bottom: var(--sp-2); }
.cart-row-price { font-size: 13px; color: var(--sale); font-weight: 600; }
.cart-row-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--sp-2);
}
.cart-row-total { font-weight: 700; font-size: 14px; }
.cart-row-remove {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--muted);
  background: none;
  border: none;
  padding: 0;
}
.cart-row-remove:hover { color: var(--sale); }
.stepper {
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.stepper button {
  width: 28px;
  background: var(--white);
  font-size: 14px;
  color: var(--ink);
}
.stepper button:hover { background: var(--bone-soft); }
.stepper input {
  width: 36px;
  text-align: center;
  border: none;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  font-size: 13px;
  padding: 4px 0;
}
.cart-summary {
  background: var(--bone-soft);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
}
@media (min-width: 1024px) {
  .cart-summary { position: sticky; top: calc(var(--header-h) + var(--sp-4)); }
}
.cart-summary h3 { margin-bottom: var(--sp-4); font-size: 16px; }
.summary-row {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  padding: var(--sp-2) 0;
  color: var(--ink-soft);
}
.summary-row--total {
  border-top: 1px solid var(--line);
  margin-top: var(--sp-3);
  padding-top: var(--sp-3);
  font-size: 16px;
  font-weight: 700;
  color: var(--ink);
}
.summary-coupon {
  display: flex;
  gap: var(--sp-2);
  margin: var(--sp-4) 0;
}
.summary-coupon .input,
.summary-coupon input[type="text"] {
  flex: 1;
  background: var(--white) !important;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px 12px;
  font-size: 14px;
  color: var(--ink);
}
.summary-coupon .input:focus,
.summary-coupon input[type="text"]:focus {
  outline: none;
  border-color: var(--ink);
  background: var(--white) !important;
}
.cart-empty {
  text-align: center;
  padding: var(--sp-8) var(--sp-4);
  border: 1px dashed var(--line);
  border-radius: var(--radius-lg);
}
.cart-empty h2 { font-family: var(--font-serif); font-weight: 400; margin-bottom: var(--sp-3); }
.cart-empty p { color: var(--muted); margin-bottom: var(--sp-5); }

/* ---------- 32. Checkout ---------- */
.checkout-steps {
  display: flex;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-5) 0;
  flex-wrap: wrap;
}
.checkout-step {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: 13px;
  color: var(--muted);
}
.checkout-step .num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
}
.checkout-step.active { color: var(--ink); }
.checkout-step.active .num { background: var(--ink); color: var(--white); border-color: var(--ink); }
.checkout-step.done .num { background: var(--success); color: var(--white); border-color: var(--success); }
.checkout-arrow { color: var(--line); }
@media (max-width: 639px) {
  .checkout-step:not(.active) .label { display: none; }
}

.checkout-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  padding-bottom: var(--sp-8);
}
@media (min-width: 1024px) {
  .checkout-layout { grid-template-columns: 1.6fr 1fr; gap: var(--sp-6); }
}
.checkout-form .form-group-title { font-size: 14px; }
.payment-options { display: flex; flex-direction: column; gap: var(--sp-2); }
.payment-option {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease);
}
.payment-option:hover { border-color: var(--ink); }
.payment-option input { accent-color: var(--ink); }
.payment-option-info { flex: 1; }
.payment-option-name { font-weight: 600; font-size: 13px; }
.payment-option-desc { font-size: 12px; color: var(--muted); }
.payment-option-price { font-weight: 600; font-size: 13px; }

.payment-note {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  background: var(--warn-bg);
  border: 1px solid var(--warn-border);
  border-radius: var(--radius);
  color: var(--warn-text);
  font-size: 13px;
  line-height: 1.55;
}
.payment-note svg { flex-shrink: 0; margin-top: 2px; color: #c79100; }
.payment-note p { margin: 0; }
.payment-note strong { color: var(--warn-text); font-weight: 700; }

.order-summary-card {
  background: var(--bone-soft);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
}
@media (min-width: 1024px) {
  .order-summary-card { position: sticky; top: calc(var(--header-h) + var(--sp-4)); }
}
.order-summary-list { display: flex; flex-direction: column; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.order-summary-item {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: var(--sp-3);
  align-items: center;
}
.order-summary-item img { width: 56px; height: 56px; border-radius: var(--radius); object-fit: cover; }
.order-summary-item .name { font-size: 13px; font-weight: 600; line-height: 1.3; }
.order-summary-item .qty { font-size: 12px; color: var(--muted); margin-top: 2px; }
.order-summary-item .price { font-size: 13px; font-weight: 600; }

/* ---------- 33. Order success ---------- */
.success-wrap {
  max-width: 680px;
  margin: 0 auto;
  padding: var(--sp-7) var(--sp-4);
  text-align: center;
}
.success-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--success);
  color: var(--white);
  margin: 0 auto var(--sp-5);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.success-wrap h1 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 32px;
  margin-bottom: var(--sp-3);
}
.success-wrap > p { color: var(--ink-soft); margin-bottom: var(--sp-6); }
.success-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  text-align: left;
  margin-bottom: var(--sp-6);
}
@media (min-width: 768px) {
  .success-grid { grid-template-columns: 1fr 1fr; }
}
.success-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
}
.success-card h4 { font-size: 13px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: var(--sp-3); color: var(--muted); }
.success-card-row { display: flex; justify-content: space-between; padding: var(--sp-2) 0; font-size: 13px; }
.success-card-row .l { color: var(--muted); }
.success-card-row .v { font-weight: 600; }
.success-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: center;
  margin-bottom: var(--sp-6);
}
.success-products {
  text-align: left;
  border-top: 1px solid var(--line);
  padding-top: var(--sp-5);
}
.success-products h4 { font-size: 13px; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); margin-bottom: var(--sp-3); }
.success-products-list { display: flex; flex-direction: column; gap: var(--sp-3); }

/* ---------- 34. Auth (login / register / forgot) ---------- */
.auth-wrap {
  max-width: 480px;
  margin: 0 auto;
  padding: var(--sp-7) var(--sp-4) var(--sp-8);
}
.auth-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
}
.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid var(--line);
  margin-bottom: var(--sp-5);
}
.auth-tab {
  padding: var(--sp-3) 0;
  font-weight: 600;
  text-align: center;
  color: var(--muted);
  border-bottom: 2px solid transparent;
  background: none;
  margin-bottom: -1px;
}
.auth-tab.active { color: var(--ink); border-bottom-color: var(--ink); }
.auth-panel { display: none; }
.auth-panel.active { display: block; }
.auth-title {
  font-family: var(--font-serif);
  font-size: 26px;
  font-weight: 400;
  text-align: center;
  margin-bottom: var(--sp-3);
}
.auth-sub { color: var(--muted); text-align: center; margin-bottom: var(--sp-5); font-size: 13px; }
.auth-row-between { display: flex; justify-content: space-between; align-items: center; margin: var(--sp-3) 0; font-size: 12px; }
.auth-link { color: var(--ink); text-decoration: underline; }
.auth-back { display: inline-flex; align-items: center; gap: 6px; margin-top: var(--sp-4); color: var(--muted); font-size: 13px; }
.auth-back:hover { color: var(--ink); }

/* ---- WC password strength meter — màu rõ ràng theo từng level ---- */
.woocommerce-password-strength {
  font-size: 12px;
  font-weight: 600;
  padding: 6px 10px;
  border-radius: var(--radius);
  margin-top: 6px;
  display: block;
  line-height: 1.4;
}
.woocommerce-password-strength.short {
  background: #fbe6e6;
  color: var(--sale);
  border: 1px solid var(--sale);
}
.woocommerce-password-strength.bad {
  background: #fff0e0;
  color: #b4761a;
  border: 1px solid #f0c87a;
}
.woocommerce-password-strength.good {
  background: #fff7e0;
  color: #8a7012;
  border: 1px solid #e6cf6a;
}
.woocommerce-password-strength.strong {
  background: #e6f7ed;
  color: var(--success);
  border: 1px solid var(--success);
}
.woocommerce-password-hint {
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
  display: block;
  line-height: 1.5;
}
/* Highlight password input red when strength too weak */
.auth-panel input[type="password"].woocommerce-Input--error,
.auth-panel input.woocommerce-password-strength-fail {
  border-color: var(--sale);
}
/* Disabled register/login button — clear visual state */
.auth-panel .btn[disabled],
.auth-panel .btn.disabled,
.auth-panel button[disabled] {
  background: #d0d0d0 !important;
  border-color: #d0d0d0 !important;
  color: var(--white) !important;
  cursor: not-allowed;
  opacity: 0.8;
}

/* ---------- 35. Account page ---------- */
.account-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  padding-bottom: var(--sp-8);
}
@media (min-width: 1024px) {
  .account-layout { grid-template-columns: 240px 1fr; gap: var(--sp-6); }
}
.account-sidebar {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
}
.account-user { text-align: center; padding-bottom: var(--sp-4); border-bottom: 1px solid var(--line); margin-bottom: var(--sp-3); }
.account-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--bone);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  font-size: 22px;
  color: var(--ink);
  margin-bottom: var(--sp-2);
}
.account-name { font-weight: 600; font-size: 14px; }
.account-email { font-size: 12px; color: var(--muted); }
.account-nav { display: flex; flex-direction: column; }
.account-nav button,
.account-nav a {
  text-align: left;
  padding: var(--sp-3);
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--ink-soft);
  background: none;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  text-decoration: none;
  border: 0;
  cursor: pointer;
  width: 100%;
}
.account-nav button:hover,
.account-nav a:hover { background: var(--bone-soft); color: var(--ink); }
.account-nav button.active,
.account-nav a.active,
.account-nav li.is-active > a { background: var(--ink); color: var(--white); }
.account-nav button svg,
.account-nav a svg { width: 16px; height: 16px; flex-shrink: 0; }
.account-nav ul { list-style: none; padding: 0; margin: 0; }
.account-nav li { margin: 0; }

/* ---------- WC-MyAccount form overrides — keep hifi form styling ---------- */
.woocommerce-MyAccount-content { min-width: 0; }
.woocommerce-MyAccount-content > p:first-child { color: var(--ink-soft); margin-bottom: var(--sp-4); font-size: 14px; }
.woocommerce-MyAccount-content .woocommerce-form-row,
.woocommerce-MyAccount-content p.form-row {
  display: block;
  margin-bottom: var(--sp-4);
}
.woocommerce-MyAccount-content .woocommerce-form-row label,
.woocommerce-MyAccount-content p.form-row label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  margin-bottom: var(--sp-2);
  color: var(--ink-soft);
}
.woocommerce-MyAccount-content .woocommerce-form-row input.input-text,
.woocommerce-MyAccount-content p.form-row input.input-text,
.woocommerce-MyAccount-content .woocommerce-Input,
.woocommerce-MyAccount-content input[type="text"],
.woocommerce-MyAccount-content input[type="email"],
.woocommerce-MyAccount-content input[type="tel"],
.woocommerce-MyAccount-content input[type="password"],
.woocommerce-MyAccount-content input[type="date"],
.woocommerce-MyAccount-content select {
  width: 100%;
  border: 1px solid var(--line);
  background: var(--white);
  padding: 10px 12px;
  font-size: 14px;
  border-radius: var(--radius);
  font-family: inherit;
  color: var(--ink);
  height: 40px;
}
.woocommerce-MyAccount-content input:focus,
.woocommerce-MyAccount-content select:focus { outline: none; border-color: var(--ink); }
.woocommerce-MyAccount-content fieldset { border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--sp-4); margin-top: var(--sp-5); }
.woocommerce-MyAccount-content fieldset legend { font-size: 14px; font-weight: 600; padding: 0 var(--sp-2); }
.woocommerce-MyAccount-content button.button,
.woocommerce-MyAccount-content button[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  border-radius: var(--radius);
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--white);
  cursor: pointer;
}
.woocommerce-MyAccount-content button.button:hover { background: var(--ink-soft); border-color: var(--ink-soft); }

/* WC orders endpoint table — reuse .order-table styles via class join */
.woocommerce-MyAccount-orders thead { background: var(--bone-soft); }
.woocommerce-orders-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.woocommerce-orders-table th,
.woocommerce-orders-table td { padding: var(--sp-3); text-align: left; border-bottom: 1px solid var(--line); vertical-align: middle; }
.woocommerce-orders-table th { font-weight: 600; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; }
.woocommerce-orders-table .woocommerce-orders-table__cell-order-actions { white-space: nowrap; }
.woocommerce-orders-table .woocommerce-button { display: inline-flex; padding: 6px 12px; font-size: 12px; border: 1px solid var(--ink); background: transparent; color: var(--ink); border-radius: var(--radius); margin-right: 4px; text-decoration: none; }
.woocommerce-orders-table .woocommerce-button:hover { background: var(--ink); color: var(--white); }
.woocommerce-pagination { margin-top: var(--sp-4); display: flex; gap: var(--sp-2); justify-content: center; }
.woocommerce-pagination ul { display: flex; gap: var(--sp-2); list-style: none; padding: 0; margin: 0; }
.woocommerce-pagination li a,
.woocommerce-pagination li span { padding: 6px 12px; border: 1px solid var(--line); border-radius: var(--radius); font-size: 13px; color: var(--ink); text-decoration: none; }
.woocommerce-pagination li .current { background: var(--ink); color: var(--white); border-color: var(--ink); }

/* WC view-order header */
.woocommerce-order-details h2,
.woocommerce-customer-details h2 { font-size: 16px; margin-bottom: var(--sp-3); }
.woocommerce-table--order-details { width: 100%; border-collapse: collapse; font-size: 13px; }
.woocommerce-table--order-details th,
.woocommerce-table--order-details td { padding: var(--sp-3); text-align: left; border-bottom: 1px solid var(--line); }
.woocommerce-table--order-details tfoot th { font-weight: 600; color: var(--muted); }
.woocommerce-table--order-details tfoot tr:last-child th,
.woocommerce-table--order-details tfoot tr:last-child td { font-size: 15px; font-weight: 700; }
.woocommerce-customer-details address { font-style: normal; font-size: 13px; color: var(--ink-soft); line-height: 1.5; }

.account-tab { display: none; }
.account-tab.active { display: block; }

.stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
@media (min-width: 768px) { .stat-grid { grid-template-columns: repeat(4, 1fr); } }
.stat-grid--single { grid-template-columns: 1fr; }
@media (min-width: 768px) { .stat-grid--single { grid-template-columns: 1fr; max-width: 360px; } }
.stat-card {
  background: var(--bone-soft);
  border-radius: var(--radius-lg);
  padding: var(--sp-4);
}
.stat-card .label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: var(--sp-2); }
.stat-card .value { font-size: 26px; font-weight: 700; color: var(--ink); letter-spacing: -0.5px; }

.order-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.order-table { border: 0 !important; }
.order-table th, .order-table td {
  padding: var(--sp-3);
  text-align: left;
  border-top: 0 !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-bottom: 1px solid var(--line) !important;
}
.order-table th { font-weight: 600; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; }
.order-table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius-lg); }
.status-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
}
.status-badge--pending { background: #f5f5f5; color: #666; }
.status-badge--processing { background: #fff7e6; color: #b4761a; }
.status-badge--shipping { background: #e6f4ff; color: var(--info); }
.status-badge--done,
.status-badge--delivered { background: #e6f7ed; color: var(--success); }
.status-badge--cancel,
.status-badge--cancelled { background: #fbe6e6; color: var(--sale); }

.address-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
}
@media (min-width: 768px) { .address-grid { grid-template-columns: 1fr 1fr; } }
.address-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--sp-4);
  position: relative;
}
.address-card.is-default { border-color: var(--ink); }
.address-default-tag {
  position: absolute;
  top: var(--sp-3);
  right: var(--sp-3);
  font-size: 10px;
  background: var(--ink);
  color: var(--white);
  padding: 2px 6px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.address-card .name { font-weight: 600; margin-bottom: var(--sp-1); }
.address-card .phone { font-size: 13px; color: var(--ink-soft); margin-bottom: var(--sp-2); }
.address-card .addr { font-size: 13px; color: var(--ink-soft); line-height: 1.5; }
.address-card-actions { display: flex; gap: var(--sp-3); margin-top: var(--sp-3); font-size: 12px; }
.address-card-actions a { color: var(--ink); text-decoration: underline; }

/* ---------- 36. Order detail / track ---------- */
.order-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.order-header h1 { font-family: var(--font-serif); font-weight: 400; font-size: 26px; }
.order-header .meta { color: var(--muted); font-size: 13px; }

.order-timeline {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-3);
  margin: var(--sp-5) 0;
  padding: var(--sp-5);
  background: var(--bone-soft);
  border-radius: var(--radius-lg);
  position: relative;
}
.timeline-step {
  flex: 1;
  text-align: center;
  position: relative;
  min-width: 0;
}
.timeline-step-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--white);
  border: 2px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-2);
  position: relative;
  z-index: 1;
}
.timeline-step.done .timeline-step-dot { background: var(--success); border-color: var(--success); color: var(--white); }
.timeline-step.current .timeline-step-dot { background: var(--ink); border-color: var(--ink); color: var(--white); }
.timeline-step-label { font-size: 12px; font-weight: 600; }
.timeline-step-date { font-size: 11px; color: var(--muted); margin-top: 2px; }
.timeline-step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 13px;
  left: 50%;
  right: -50%;
  height: 2px;
  background: var(--line);
  z-index: 0;
}
.timeline-step.done:not(:last-child)::after { background: var(--success); }
@media (max-width: 639px) {
  .order-timeline { flex-direction: column; align-items: flex-start; padding: var(--sp-4); }
  .timeline-step { display: flex; align-items: center; text-align: left; gap: var(--sp-3); width: 100%; }
  .timeline-step-dot { margin-bottom: 0; }
  .timeline-step:not(:last-child)::after { left: 13px; top: 28px; right: auto; bottom: -16px; width: 2px; height: 16px; }
  .timeline-step-info { display: flex; flex-direction: column; }
}

.order-detail-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
@media (min-width: 1024px) {
  .order-detail-layout { grid-template-columns: 1.6fr 1fr; gap: var(--sp-6); }
}

/* ---------- 37. Track order form ---------- */
.track-wrap { max-width: 620px; margin: 0 auto; padding: var(--sp-7) var(--sp-4) var(--sp-8); }

/* ===========================================================================
   38. WC core bridges (Task 6.6)
   --------------------------------------------------------------------------
   The cart/checkout templates render real WooCommerce form fields and payment
   gateway markup. These rules harmonize WC's default classes (.input-text,
   .woocommerce-input-wrapper, .wc_payment_method, etc.) with the hifi-v2
   design tokens.
   =========================================================================== */

/* Cart row title link should not be underlined like body text */
.cart-row-name a { color: inherit; text-decoration: none; }
.cart-row-name a:hover { color: var(--sale); }

/* Add-on lines under product name */
.cart-row-addon {
  font-size: 12px;
  color: var(--ink-soft);
  margin-bottom: 2px;
  line-height: 1.4;
}
.order-summary-item .addon {
  font-size: 11px;
  color: var(--ink-soft);
  margin-top: 2px;
  line-height: 1.4;
}

/* Cart thumbnail — WC outputs <img class="attachment-woocommerce_thumbnail size-woocommerce_thumbnail"> */
.cart-row-img a { display: block; width: 100%; height: 100%; }
.cart-row-img img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Price per-unit suffix */
.cart-row-price-per { color: var(--muted); font-weight: 400; margin-left: 4px; font-size: 12px; }

/* Quantity wrapper around stepper */
.cart-row-qty-wrap { margin-top: var(--sp-3); }

/* Stepper input number — hide spin arrows */
.stepper-input::-webkit-outer-spin-button,
.stepper-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.stepper-input[type="number"] { -moz-appearance: textfield; }

/* Cart actions bottom row (continue shopping + hidden update button) */
.cart-actions-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--sp-4);
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.cart-update-btn {
  /* Hidden visually — fired by stepper JS for graceful no-JS fallback to "submit" */
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Free shipping note under checkout button */
.summary-free-ship-note {
  font-size: 12px;
  color: var(--muted);
  margin-top: var(--sp-3);
  text-align: center;
}

/* Shipping "free" inline label */
.cart-shipping-free { color: var(--success); font-weight: 600; }

/* Subtle italic muted text used in cart shipping placeholder */
.summary-row .muted-italic { color: var(--muted); font-style: italic; }

/* Hide WC core wrapper headings/labels we don't render visually */
.cart_totals > h2 { display: none; } /* WC default "Cart totals" h2 (we render h3) */
.woocommerce-billing-fields > h3 { display: none; } /* WC "Billing details" h3 (we render form-group-title via PHP) */

/* WC field <p> wrapper was already converted to <div> via PHP filter.
   Make sure WC's `validate-required` / `woocommerce-validated` / `woocommerce-invalid`
   variants share the same form-row styling. */
.form-row.validate-required,
.form-row.woocommerce-validated,
.form-row.woocommerce-invalid { margin-bottom: var(--sp-4); }

.form-row .required {
  color: var(--sale);
  font-weight: 600;
  margin-left: 2px;
}

/* WC core wraps inputs in <span class="woocommerce-input-wrapper">. Make wrapper inline-block + full width */
.woocommerce-input-wrapper { display: block; width: 100%; }
.woocommerce-input-wrapper .input,
.woocommerce-input-wrapper .input-text,
.woocommerce-input-wrapper .select,
.woocommerce-input-wrapper .textarea {
  width: 100%;
}

/* WC core's .input-text equivalent → match hifi .input */
.checkout-form input.input-text,
.checkout-form input[type="text"],
.checkout-form input[type="tel"],
.checkout-form input[type="email"],
.checkout-form input[type="number"],
.checkout-form input[type="password"],
.checkout-form select,
.checkout-form textarea {
  width: 100%;
  padding: 10px 12px;
  font-size: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--white);
  transition: border-color var(--t-fast) var(--ease);
  font-family: inherit;
  color: var(--ink);
}
.checkout-form input.input-text:focus,
.checkout-form input:focus,
.checkout-form select:focus,
.checkout-form textarea:focus {
  outline: none;
  border-color: var(--ink);
}
.checkout-form textarea { resize: vertical; min-height: 90px; }

/* Group "Họ tên" + "Tên đệm" + "SĐT" + "Email" + "Tỉnh" + "Quận" on 2-col grid on desktop.
   WC renders each field as its own .form-row div — we make the WRAPPER a grid. */
.checkout-billing-fields,
.checkout-shipping-fields .woocommerce-shipping-fields__field-wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3) var(--sp-4);
}
@media (min-width: 640px) {
  .checkout-billing-fields,
  .checkout-shipping-fields .woocommerce-shipping-fields__field-wrapper {
    grid-template-columns: 1fr 1fr;
  }
  /* Full-width rows */
  .checkout-billing-fields .form-row--email,
  .checkout-billing-fields .form-row--address,
  .checkout-billing-fields .form-row--postcode,
  .checkout-billing-fields .form-row--note,
  .checkout-shipping-fields .form-row--email,
  .checkout-shipping-fields .form-row--address {
    grid-column: 1 / -1;
  }
}

/* Hide last_name (we collapse "Họ và tên" into first_name) — actually we keep
   it visible per VN customary but mark not required. To match hifi mock which
   only has 1 name field, hide last_name entirely. */
.checkout-billing-fields .form-row--last-name,
.checkout-shipping-fields .form-row--last-name {
  display: none;
}

/* Hide country (VN-only shop) */
.checkout-billing-fields .form-row--country,
.checkout-shipping-fields .form-row--country,
.form-row--hidden { display: none; }

/* Postcode optional — keep visible but compact */
.checkout-billing-fields .form-row--postcode,
.checkout-shipping-fields .form-row--postcode { display: none; }
/* (uncomment line above is overridden — we still hide postcode because hifi doesn't show.
   Re-enable later if VN postcode becomes mandatory.) */

/* Order notes textarea — full width below address */
.checkout-additional-fields { margin-top: var(--sp-4); }
.checkout-additional-fields .form-row { margin-bottom: 0; }

/* Ship-to-different-address toggle */
.form-group-title--toggle {
  border-bottom: none;
  padding-bottom: 0;
  font-size: 14px;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
  color: var(--ink-soft);
}
/* Match hifi checkbox alignment — inline-flex center, gap consistent. */
.form-group-title--toggle .checkbox {
  display: inline-flex !important;
  align-items: center;
  gap: var(--sp-2);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  margin: 0;
}
.form-group-title--toggle .checkbox span {
  line-height: 1;
  vertical-align: middle;
}

/* ============================================================
   UNIVERSAL CHECKBOX BRAND — !important để override Blocksy parent
   + WC core CSS đè bằng higher specificity.
   ============================================================ */
body input[type="checkbox"] {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 1.5px solid #d4d4d4 !important;
  border-radius: 4px !important;
  background: #fff !important;
  background-color: #fff !important;
  background-image: none !important;
  cursor: pointer;
  position: relative;
  outline: none !important;
  box-shadow: none !important;
  vertical-align: middle;
  accent-color: #1a1a1a;
  flex-shrink: 0;
  opacity: 1 !important;
  visibility: visible !important;
}
body input[type="checkbox"]:hover {
  border-color: #1a1a1a !important;
}
body input[type="checkbox"]:checked {
  background-color: #1a1a1a !important;
  border-color: #1a1a1a !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3.5 8.5 6.5 11.5 12.5 4.5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 12px 12px !important;
}
body input[type="checkbox"]:focus-visible {
  outline: 2px solid #f5efe6 !important;
  outline-offset: 2px;
}

/* Payment methods — bridge .wc_payment_method (WC <li>) → hifi payment-option look */
/* =================================================================
   Payment methods list — custom brand radio.
   Apply cho cả /checkout/ và /checkout/order-pay/ vì cùng markup
   `<ul class="wc_payment_methods"><li class="wc_payment_method">`.
   ================================================================= */
.wc_payment_methods,
.wc_payment_methods.payment-options,
.wc_payment_methods.payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.wc_payment_methods .wc_payment_method {
  display: block;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px var(--sp-4);
  background: var(--white, #fff);
  position: relative;
}
/* Card không đổi visual khi selected — chỉ radio dot xác định state.
   (Trước có border đen + bg cream → user feedback xấu.) */

/* Custom radio brand — circle 18px với dot ink khi checked.
   Dùng !important để override Blocksy parent + WC core. */
body input[type="radio"] {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 1.5px solid #d4d4d4 !important;
  border-radius: 50% !important;
  background: #fff !important;
  background-color: #fff !important;
  background-image: none !important;
  cursor: pointer;
  position: relative;
  vertical-align: middle;
  outline: none !important;
  box-shadow: none !important;
  accent-color: #1a1a1a;
  flex-shrink: 0;
  opacity: 1 !important;
  visibility: visible !important;
}
body input[type="radio"]:hover { border-color: #1a1a1a !important; }
body input[type="radio"]:checked {
  border-color: #1a1a1a !important;
  background-color: #fff !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='4' fill='%231a1a1a'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 16px 16px !important;
}
body input[type="radio"]:focus-visible {
  outline: 2px solid #f5efe6 !important;
  outline-offset: 2px;
}

/* Label row: [radio] [title + icon] */
.wc_payment_methods .wc_payment_method label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  font-size: 14px;
  color: var(--ink);
  cursor: pointer;
  margin: 0;
}
.wc_payment_methods .wc_payment_method label img {
  max-height: 24px;
  width: auto;
  display: inline-block;
}

/* Wrap radio + label inline để align ngang */
.wc_payment_methods .wc_payment_method > input[type="radio"] {
  margin-right: 12px;
}

/* Description box dưới — render khi method được chọn */
.wc_payment_methods .wc_payment_method .payment_box {
  margin-top: 10px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.6);
  border: 1px dashed var(--line, #d4d4d4);
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--ink-soft, #5a5a5a);
  line-height: 1.55;
}
.wc_payment_methods .wc_payment_method .payment_box p { margin: 0 0 6px; }
.wc_payment_methods .wc_payment_method .payment_box p:last-child { margin-bottom: 0; }

/* WC notices on cart/checkout */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  list-style: none;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius);
  margin-bottom: var(--sp-4);
  font-size: 13px;
  line-height: 1.55;
}
.woocommerce-message { background: #e6f7ed; color: #14532d; border: 1px solid #b9e7c8; }
.woocommerce-info    { background: #e6f4ff; color: #0c4a6e; border: 1px solid #b9dfff; }
.woocommerce-error   { background: #fbe6e6; color: #7a1313; border: 1px solid #efb7b7; }

/* CHECKOUT-only: ẨN khối notice top (top pink banner duplicate với inline error per field).
   JS convertCartNoticesToToast() ở cart-checkout.js đã chuyển notice thành toast,
   plus mỗi field required đã có inline field-error riêng → top banner thừa. */
.woocommerce-checkout > .woocommerce-NoticeGroup-checkout,
.woocommerce-checkout > .woocommerce-error,
.woocommerce-checkout > .woocommerce-notices-wrapper,
form.checkout > .woocommerce-NoticeGroup-checkout,
form.checkout > .woocommerce-error,
form.checkout > .woocommerce-notices-wrapper {
  display: none !important;
}

/* Inline field error — WC checkout.min.js render <p class="checkout-inline-error-message">
   append vào .form-row + add aria-invalid="true" lên field invalid.
   Style cho match input + select + textarea đồng nhất. */

/* Field state invalid (cả input + select + textarea) */
.checkout-form input[aria-invalid="true"],
.checkout-form select[aria-invalid="true"],
.checkout-form textarea[aria-invalid="true"],
.woocommerce-invalid input,
.woocommerce-invalid select,
.woocommerce-invalid textarea {
  border-color: #d33 !important;
  background: #fff7f7 !important;
}

/* Inline error message render dưới field — INLINE (in flow), tight gap.
   Pair với rule grid align-items:start + align-self:start ở cuối block này
   để 2 col luôn align top, KHÔNG bị 1 col stretch theo col còn lại. */
.checkout-inline-error-message {
  display: block;
  margin: 4px 0 0 !important;
  padding: 0;
  background: transparent;
  border: 0;
  color: #c62828;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
}

/* Force 2-col grid (.checkout-billing-fields, etc) ALIGN TOP — không stretch.
   Mặc định grid `align-items: stretch` → cell trái stretch theo cell phải có error
   text → giả tạo gap dưới col trái. align-items: start làm cell chỉ chiếm content
   height, label + select cả 2 col luôn align top. */
.checkout-billing-fields,
.checkout-shipping-fields .woocommerce-shipping-fields__field-wrapper {
  align-items: start;
}
.checkout-billing-fields > .form-row,
.checkout-shipping-fields .woocommerce-shipping-fields__field-wrapper > .form-row {
  align-self: start;
}

/* Fallback cho WC native rendering (nếu inline notice cũ vẫn có) */
.woocommerce-invalid > .woocommerce-error,
.woocommerce-invalid > ul.woocommerce-error,
p.form-row .woocommerce-error,
div.form-row .woocommerce-error {
  margin: 4px 0 0;
  padding: 0;
  background: transparent;
  border: 0;
  color: #c62828;
  font-size: 12px;
  font-weight: 500;
  list-style: none;
}

/* Reduce form-row margin-bottom khi field invalid (vì có error text dưới
   chiếm space rồi, không cần extra margin). */
.checkout-form .form-row:has([aria-invalid="true"]),
.checkout-form .form-row.woocommerce-invalid {
  margin-bottom: var(--sp-3);
}

/* Terms + privacy policy checkbox group at end of checkout */
.woocommerce-terms-and-conditions-wrapper {
  margin-top: var(--sp-4);
  margin-bottom: var(--sp-4);
}
.woocommerce-terms-and-conditions-wrapper .form-row { margin-bottom: 0; }

/* Place order button — already styled via .btn.btn--cta; but WC core button.alt may apply */
.checkout-form button.button.alt,
.checkout-form button.place-order-btn,
#place_order {
  /* Inherit from .btn already; no override needed unless WC sets bg */
}

/* Mobile sticky checkout button on cart page (option) */
@media (max-width: 1023px) {
  .cart-summary {
    /* On mobile, summary is at the bottom — sticky checkout CTA sits above safe area */
  }
}

/* Hide WC default order-overview list + order-details table + customer-details
   on thank-you page (we render our own success-card grid + success-products list).
   The default markup loads from woocommerce_thankyou action — let it run for
   plugin extensibility but visually suppress duplicate content. */
.order-success-wrap .woocommerce-order-details,
.order-success-wrap .woocommerce-customer-details,
.order-success-wrap .woocommerce-bacs-bank-details {
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--line);
  font-size: 13px;
  color: var(--ink-soft);
}
.order-success-wrap .woocommerce-order-details h2,
.order-success-wrap .woocommerce-customer-details h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 18px;
  margin-bottom: var(--sp-3);
}
.order-success-wrap .woocommerce-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.order-success-wrap .woocommerce-table th,
.order-success-wrap .woocommerce-table td {
  padding: var(--sp-3);
  text-align: left;
  border-bottom: 1px solid var(--line);
}
.order-success-wrap .woocommerce-table th {
  font-weight: 600;
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Order success — failed icon variant */
.success-icon--fail {
  background: var(--sale);
  color: var(--white);
  font-family: var(--font-serif);
  font-size: 36px;
  font-weight: 700;
}

/* Order success — 4-step timeline already styled via .order-timeline. Compact for thank you. */
.success-steps { margin: var(--sp-6) 0; }

/* Order summary item meta wrapper (when nested under <div>) */
.order-summary-item-meta { min-width: 0; }
.order-summary-item .name { word-break: break-word; }

/* Order summary card responsive — collapse toggle on mobile */
.order-summary-card-title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 20px;
  margin-bottom: var(--sp-4);
  cursor: default;
}
@media (max-width: 1023px) {
  .order-summary-card-title {
    cursor: pointer;
    position: relative;
    padding-right: 24px;
    margin-bottom: 0;
  }
  .order-summary-card-title::after {
    content: '▾';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    transition: transform var(--t-fast) var(--ease);
    color: var(--muted);
    font-size: 14px;
  }
  .order-summary-card.is-collapsed .order-summary-card-title::after {
    transform: translateY(-50%) rotate(-90deg);
  }
  .order-summary-card.is-collapsed > *:not(.order-summary-card-title) {
    display: none;
  }
  .order-summary-card > *:first-child + * { margin-top: var(--sp-4); }
}

/* WC quantity input (for non-stepper rendering) */
.woocommerce-cart-form .quantity {
  display: inline-flex;
}

/* WC's noscript fallback hidden when JS available */
html.js .checkout-form noscript { display: none; }

/* Ensure cart row mobile single col stacks nicely (override grid for narrow screens) */
@media (max-width: 480px) {
  .cart-row {
    grid-template-columns: 64px 1fr;
    grid-template-rows: auto auto;
  }
  .cart-row-img { width: 64px; height: 64px; }
  .cart-row-actions {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    border-top: 1px solid var(--line);
    padding-top: var(--sp-3);
    margin-top: var(--sp-2);
  }
}

/* ===================================================================
 * Task 6.6 hardening — Checkout parity with hifi-v2/checkout.html
 *   - Agree checkbox row
 *   - Hidden form rows (last_name, postcode, country)
 *   - Hide CusRev opt-in (paranoia: even if cr_consent_checkbox filter fails)
 *   - Hide WC privacy notice wrapper (filter returns empty but wrapper may still render)
 * =================================================================== */
.checkout-agree-row {
  margin-top: var(--sp-5);
  margin-bottom: var(--sp-3);
}
.checkout-agree {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink);
  cursor: pointer;
}

/* Terms checkbox: chỉ tweak margin-top + text spacing. Visual base inherit
   từ universal `body.woocommerce-page input[type="checkbox"]` ở trên. */
.checkout-agree input[type="checkbox"] {
  margin-top: 2px;
}

.checkout-agree .woocommerce-terms-and-conditions-checkbox-text {
  flex: 1;
}
.checkout-agree a {
  color: var(--ink, #1a1a1a);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.checkout-agree a:hover { color: var(--burgundy, #6b1f2d); }
.checkout-agree .required {
  color: var(--burgundy, #6b1f2d);
  margin-left: 4px;
  text-decoration: none;
  border: 0;
}

/* Hidden compatibility WC fields — display:none but still in DOM for validation */
.checkout-hidden-fields,
.form-row--hidden { display: none !important; }

/* CusRev opt-in — defensive hide if filter cr_consent_checkbox didn't fully remove */
.cr-customer-consent,
.cr-customer-consent-checkbox { display: none !important; }

/* WC privacy policy wrapper — should be empty after filter, but hide just in case */
.woocommerce-privacy-policy-text:empty,
.woocommerce-terms-and-conditions-wrapper > p:empty { display: none; }

/* Match hifi class names verbatim for grid layout consistency. */
.form-row--2col,
.form-row--2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
@media (max-width: 640px) {
  .form-row--2col,
  .form-row--2 { grid-template-columns: 1fr; }
}

/* Order summary right card — list + rows */
.order-summary-items { list-style: none; margin: 0 0 var(--sp-4); padding: 0; }
.order-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-2) 0;
  font-size: 14px;
}
.order-summary-row .free { color: var(--success); font-weight: 600; }
.order-summary-total {
  border-top: 1px solid var(--line);
  margin-top: var(--sp-2);
  padding-top: var(--sp-3);
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 600;
}

/* Force VN address state visible (override WC JS inline display:none) */
#billing_state_field,
#shipping_state_field {
    display: grid !important;
}

/* ---------- Select2 dropdown styling (match native input look) ---------- */
.select2-container--default .select2-selection--single {
  height: 40px !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--radius) !important;
  background: var(--white) !important;
  padding: 0 !important;
  font-family: var(--font) !important;
  display: flex !important;
  align-items: center !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 38px !important;
  padding: 0 12px !important;
  color: var(--ink) !important;
  font-size: 14px !important;
  font-family: var(--font) !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 38px !important;
  right: 6px !important;
  top: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: var(--muted) !important;
  font-size: 14px !important;
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--ink) !important;
  outline: none !important;
}
/* Dropdown panel */
.select2-dropdown {
  border: 1px solid var(--line) !important;
  border-radius: var(--radius) !important;
  background: var(--white) !important;
  font-family: var(--font) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.select2-results__option {
  padding: 10px 14px !important;
  font-size: 14px !important;
  color: var(--ink) !important;
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
  background: var(--bone-soft) !important;
  color: var(--ink) !important;
}
.select2-container--default .select2-results__option[aria-selected=true] {
  background: var(--line) !important;
  color: var(--ink) !important;
}
.select2-search--dropdown .select2-search__field {
  border: 1px solid var(--line) !important;
  border-radius: var(--radius) !important;
  padding: 8px 12px !important;
  font-size: 14px !important;
}

/* ---------- Cart confirm modal (remove item) ---------- */
.cart-confirm-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
}
.cart-confirm-modal--open {
  display: flex;
}
.cart-confirm-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(2px);
}
.cart-confirm-dialog {
  position: relative;
  background: var(--white);
  border-radius: var(--radius);
  padding: 24px;
  width: min(420px, 92vw);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
  text-align: center;
  animation: cartConfirmIn 0.2s ease-out;
}
@keyframes cartConfirmIn {
  from { transform: translateY(-20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.cart-confirm-title {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--ink);
}
.cart-confirm-desc {
  color: var(--ink-soft);
  margin: 0 0 20px;
  font-size: 14px;
}
.cart-confirm-actions {
  display: flex;
  gap: var(--sp-3);
  justify-content: center;
}
.cart-confirm-actions .btn { min-width: 100px; }

/* =========================================================================
   Pay for order page (form-pay.php override)
   URL: /checkout/order-pay/{id}/?pay_for_order=true&key=...
   Khách trả tiền cho 1 đơn pending/failed có sẵn.
   ========================================================================= */

.page-hero--compact {
  padding: var(--sp-7) 0 var(--sp-7);
  margin-bottom: var(--sp-5);
  text-align: center !important;
}
.page-hero--compact .page-hero-title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 28px;
  line-height: 1.2;
  margin: 0 auto !important;
  color: var(--ink);
  text-align: center !important;
}
@media (min-width: 768px) {
  .page-hero--compact .page-hero-title { font-size: 36px; }
}
.page-hero--compact .page-hero-sub {
  margin: 12px auto 0 !important;
  max-width: none !important;
  color: var(--muted);
  font-size: 14px;
  text-align: center !important;
}

.pay-for-order { display: block; }

.pay-for-order-form .form-group-title--first {
  margin-top: 0;
}

.pay-for-order-payment { margin-top: var(--sp-3); }
/* Payment radio styles inherit from .wc_payment_methods .wc_payment_method (defined earlier) — DRY */

.pay-for-order-no-gateways,
.pay-for-order-already-paid {
  padding: var(--sp-4);
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  text-align: center;
  font-size: 14px;
  color: var(--ink-soft);
}

.pay-for-order-actions {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
}
.pay-for-order-actions .woocommerce-terms-and-conditions-wrapper {
  font-size: 13px;
}

.btn-place-order {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  width: 100%;
  padding: 16px var(--sp-5);
  background: var(--burgundy, #6b1f2d);
  color: #fff;
  border: 0;
  border-radius: var(--radius);
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.05s ease;
}
.btn-place-order:hover { background: #5a1827; }
.btn-place-order:active { transform: translateY(1px); }
.btn-place-order:disabled { opacity: 0.55; cursor: not-allowed; }
.btn-place-order .lock-icon { font-size: 14px; }
.btn-place-order .total-amount {
  margin-left: auto;
  font-weight: 700;
}

.pay-for-order-summary .order-summary-title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 20px;
  margin: 0 0 var(--sp-4);
  color: var(--ink);
}

.pay-for-order-note {
  margin-top: var(--sp-4);
  padding: var(--sp-3);
  background: var(--cream);
  border-radius: var(--radius);
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}

/* ============================================================================
 * Bank QR receipt page — /thanh-toan/{id}/?key=...
 * ========================================================================= */
.bank-qr-page { padding: var(--sp-7) 0; min-height: 60vh; }
.bank-qr-page .container { max-width: 920px; margin: 0 auto; padding: 0 var(--sp-4); }

.bank-qr-hero { text-align: center; margin-bottom: var(--sp-6); }
.bank-qr-hero-icon {
  width: 64px; height: 64px;
  margin: 0 auto var(--sp-3);
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--bone-soft);
  color: var(--ink);
}
.bank-qr-hero h1 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 24px;
  margin: 0 0 var(--sp-2);
  color: var(--ink);
}
.bank-qr-hero-sub {
  color: var(--ink-soft);
  font-size: 14px;
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.5;
}

.bank-qr-layout {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--sp-6);
  align-items: start;
  margin-bottom: var(--sp-6);
}
@media (max-width: 720px) {
  .bank-qr-layout {
    grid-template-columns: 1fr;
    gap: var(--sp-4);
  }
}

.bank-qr-img-wrap { text-align: center; }
.bank-qr-img {
  width: 100%;
  max-width: 320px;
  height: auto;
  border-radius: var(--radius);
  background: var(--white);
  border: 1px solid var(--line);
  padding: 8px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
}
.bank-qr-img-caption {
  margin-top: var(--sp-2);
  font-size: 12px;
  color: var(--ink-soft);
}

.bank-qr-info-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--sp-4);
}
.bank-qr-info-card h4 {
  margin: 0 0 var(--sp-3);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}

.bank-qr-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--line);
  gap: var(--sp-3);
}
.bank-qr-row:last-of-type { border-bottom: 0; }
.bank-qr-row-label {
  font-size: 13px;
  color: var(--ink-soft);
  flex-shrink: 0;
}
.bank-qr-row-value {
  font-size: 15px;
  color: var(--ink);
  text-align: right;
  word-break: break-word;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: transparent;
  border: 0;
  padding: 0;
  cursor: default;
  font-family: inherit;
}
.bank-qr-row-value--small { font-size: 13px; line-height: 1.4; }
.bank-qr-row--highlight .bank-qr-row-value strong { color: var(--cta-red); font-weight: 600; }

button.bank-qr-row-value.bank-qr-copy { cursor: pointer; }
.bank-qr-copy-label {
  font-size: 11px;
  color: var(--ink-soft);
  background: var(--bone-soft);
  padding: 2px 8px;
  border-radius: 999px;
  transition: background var(--t-fast) var(--ease);
}
.bank-qr-copy:hover .bank-qr-copy-label { background: var(--ink); color: var(--white); }

.bank-qr-note {
  margin-top: var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bone-soft);
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.5;
}
.bank-qr-note p:last-child { margin-bottom: 0; }

.bank-qr-actions { text-align: center; }
.bank-qr-actions .bank-qr-paid-btn {
  min-width: 280px;
  padding: 16px 32px;
}
.bank-qr-paid-btn.is-loading {
  opacity: 0.7;
  cursor: wait;
}
.bank-qr-actions-note {
  margin-top: var(--sp-3);
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.5;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

.mei-bank-qr-status {
  margin: 0 auto var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--radius);
  font-size: 14px;
  max-width: 480px;
}
.mei-bank-qr-status--success { background: #e8f5e9; color: #1b5e20; }
.mei-bank-qr-status--error   { background: #ffebee; color: #b71c1c; }
.mei-bank-qr-status--info    { background: var(--bone-soft); color: var(--ink-soft); }

.bank-qr-help {
  margin-top: var(--sp-7);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}
.bank-qr-help details {
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--line);
}
.bank-qr-help summary {
  cursor: pointer;
  font-size: 14px;
  color: var(--ink);
  padding: var(--sp-1) 0;
  list-style: none;
}
.bank-qr-help summary::-webkit-details-marker { display: none; }
.bank-qr-help summary::before { content: '+ '; color: var(--ink-soft); }
.bank-qr-help details[open] summary::before { content: '− '; }
.bank-qr-help p {
  margin: var(--sp-2) 0 0;
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.5;
}
.bank-qr-help a { color: var(--ink); text-decoration: underline; }
