/**
 * Toronto Vape 360 — WooCommerce cart page
 * Dedicated cart-only styles that use global + Woo tokens.
 */

body.woocommerce-cart {
  background: var(--wc-page-bg, #f7f5f0);
}

.woocommerce img, .woocommerce-page img {
    max-width: unset;
}

body.woocommerce-cart .navbar:not(.scrolled) .icon-btn {
    background: rgba(5, 16, 57, 0.06);
    border-color: rgba(5, 16, 57, 0.14);
}

body.woocommerce-cart .navbar:not(.scrolled) .icon-btn img{
	filter: brightness(0) saturate(100%) invert(11%) sepia(15%) saturate(2861%) hue-rotate(192deg) brightness(96%) contrast(101%);
}

body.woocommerce-cart .navbar:not(.scrolled) .hamburger span {
  background: var(--black);
}

body.woocommerce-cart .navbar:not(.scrolled) .search-btn {
    color: unset;
}

body.woocommerce-cart .navbar:not(.scrolled) .icon-btn:hover {
  background: rgba(4, 157, 191, 0.2);
  border-color: var(--blue);
  color: var(--blue);
}

.woocommerce table.shop_table_responsive tr:nth-child(2n) td, .woocommerce-page table.shop_table_responsive tr:nth-child(2n) td {
        background-color: unset;
    }

body.woocommerce-cart .cart-collaterals .cart_totals .shop_table tbody th::before,
body.woocommerce-cart .cart-collaterals .cart_totals .shop_table tbody td::before,
body.woocommerce-cart .cart-collaterals .cart_totals tr.order-total th::before,
body.woocommerce-cart .cart-collaterals .cart_totals tr.order-total td::before {
  content: none !important;
  display: none !important;
}

/* Fix shipping row — align value cell content to the left */
body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping td {
  text-align: left !important;
  vertical-align: top;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping td > * {
  text-align: left !important;
}

/* Match site container behavior on cart page */
body.woocommerce-cart .container-inner,
body.woocommerce-cart .woocommerce {
  max-width: 1440px;
  width: min(100%, 1440px);
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(16px, 4vw, 40px);
  padding-right: clamp(16px, 4vw, 40px);
}

body.woocommerce-cart > main {
  margin-top: clamp(160px, 16vw, 250px);
}

a.button.wc-backward{
	width: 100%;
}

body.woocommerce-cart .woocommerce {
  margin-bottom: clamp(28px, 5vw, 52px);
}

/* Override WooCommerce default column floats/widths */
body.woocommerce-cart .woocommerce-cart-form {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
}

body.woocommerce-cart .cart-collaterals {
  float: none !important;
  width: 100% !important;
  margin: 20px 0 0 !important;
}

body.woocommerce-cart .woocommerce::after,
body.woocommerce-cart .cart-collaterals::after {
  content: "";
  display: table;
  clear: both;
}

body.woocommerce-cart .woocommerce-cart-form table.shop_table,
body.woocommerce-cart table.shop_table.cart {
  width: 100% !important;
}

/* Keep cart typography aligned with global theme type system */
body.woocommerce-cart .woocommerce,
body.woocommerce-cart .woocommerce p,
body.woocommerce-cart .woocommerce td,
body.woocommerce-cart .woocommerce th,
body.woocommerce-cart .woocommerce label,
body.woocommerce-cart .woocommerce input,
body.woocommerce-cart .woocommerce select,
body.woocommerce-cart .woocommerce textarea {
  font: var(--body-m);
  color: var(--black);
}

body.woocommerce-cart .woocommerce h1,
body.woocommerce-cart .woocommerce h2,
body.woocommerce-cart .woocommerce h3,
body.woocommerce-cart .woocommerce .page-title {
  font: var(--h2);
  color: var(--black);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

body.woocommerce-cart .woocommerce-cart-form,
body.woocommerce-cart .cart-collaterals {
  background: var(--wc-card-bg, var(--white));
  border: 1px solid var(--wc-card-border, rgba(5, 16, 57, 0.08));
  border-radius: var(--wc-radius-card, 14px);
  box-shadow: var(--wc-card-shadow, 0 4px 20px rgba(5, 16, 57, 0.06));
}

body.woocommerce-cart .woocommerce-cart-form {
  padding: clamp(14px, 2vw, 24px);
}

body.woocommerce-cart table.shop_table {
  border: 0 !important;
  border-collapse: separate;
  border-spacing: 0;
  margin: 0 !important;
}

/* Only the line-items table — Cart totals also uses .shop_table and must stay a normal table */
body.woocommerce-cart .woocommerce-cart-form table.shop_table thead th {
  font: var(--body-text);
  color: rgba(13, 13, 13, 0.65);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--wc-card-border, rgba(5, 16, 57, 0.08));
  padding: 12px 10px;
}

body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody td {
  border-top: 1px solid rgba(5, 16, 57, 0.08);
  padding: clamp(12px, 1.8vw, 18px) 10px;
  vertical-align: middle;
}

body.woocommerce-cart table.shop_table td.product-thumbnail img {
  width: clamp(58px, 8vw, 84px);
  border-radius: 10px;
  border: 1px solid rgba(5, 16, 57, 0.1);
  background: #fff;
  padding: 4px;
}

body.woocommerce-cart table.shop_table td.product-name a {
  font: var(--body-text);
  color: var(--grey);
  text-decoration: none;
  transition: color 0.2s ease;
}

body.woocommerce-cart table.shop_table td.product-name a:hover {
  color: var(--blue);
}

body.woocommerce-cart table.shop_table td.product-price,
body.woocommerce-cart table.shop_table td.product-subtotal {
  font: 700 16px/1.3 "DM Sans", sans-serif;
  color: var(--brown);
}

body.woocommerce-cart table.shop_table td.product-remove a.remove {
  width: 34px;
  height: 34px;
  line-height: 30px;
  border-radius: 50%;
  border: 1px solid rgba(235, 0, 0, 0.2);
  color: var(--red) !important;
  background: rgba(235, 0, 0, 0.06);
  transition: all 0.2s ease;
}

body.woocommerce-cart table.shop_table td.product-remove a.remove:hover {
  background: var(--red);
  color: var(--white) !important;
  border-color: var(--red);
}

body.woocommerce-cart .quantity .qty {
  min-height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(5, 16, 57, 0.14);
  padding: 0 12px;
  min-width: 88px;
}

body.woocommerce-cart .actions {
  padding-top: 16px !important;
}

body.woocommerce-cart .actions .coupon {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

body.woocommerce-cart .actions .coupon .input-text {
  min-height: 46px;
  min-width: min(280px, 100%);
  border: 1px solid var(--wc-card-border, rgba(5, 16, 57, 0.08));
  border-radius: 999px;
  padding: 10px 16px !important;
  font: var(--body-s);
}

body.woocommerce-cart .actions button.button,
body.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button,
body.woocommerce-cart .return-to-shop .button {
  border-radius: 999px !important;
  border: 0 !important;
  padding: 12px 22px !important;
  font: var(--body-btn) !important;
  text-decoration: none !important;
  color: var(--white) !important;
  background: var(--blue) !important;
  box-shadow: 0 6px 16px rgba(4, 157, 191, 0.26);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button{
	width: 100%
}

body.woocommerce-cart .actions button.button:hover,
body.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button:hover,
body.woocommerce-cart .return-to-shop .button:hover {
  background: #0389a6 !important;
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(4, 157, 191, 0.3);
}

body.woocommerce-cart .cart-collaterals {
  margin-top: 20px;
  padding: clamp(14px, 2.2vw, 24px);
}

body.woocommerce-cart .cart-collaterals .cart_totals {
  width: 100% !important;
  float: none !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals table.shop_table {
  table-layout: fixed;
  width: 100%;
}

body.woocommerce-cart .cart-collaterals .cart_totals h2 {
  font: var(--h5);
  color: var(--grey);
  text-transform: uppercase;
  margin: 0 0 14px;
}

body.woocommerce-cart .cart-collaterals .shop_table th,
body.woocommerce-cart .cart-collaterals .shop_table td {
  border-top: 1px solid rgba(5, 16, 57, 0.1) !important;
  padding: 10px 0 !important;
  vertical-align: top;
}

/* Label column / amount column */
body.woocommerce-cart .cart-collaterals .cart_totals .shop_table tbody th {
  text-align: left;
  font-weight: 600;
  width: 40%;
  padding-right: 12px !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals .shop_table tbody td {
  padding-left: 12px !important;
}

/* Shipping row */
body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping th {
  vertical-align: top;
  padding-top: 12px !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping td {
  padding-top: 12px !important;
}

body.woocommerce-cart .cart-collaterals .woocommerce-shipping-destination {
  text-align: left !important;
  margin: 0 0 8px !important;
}

body.woocommerce-cart .cart-collaterals .woocommerce-shipping-calculator {
  text-align: left;
}

body.woocommerce-cart .cart-collaterals a.shipping-calculator-button {
  display: inline-block;
  margin: 0 0 10px;
  text-align: left;
  text-decoration: none;
  color: var(--blue);
}

body.woocommerce-cart .cart-collaterals ul#shipping_method {
  margin: 0 0 10px !important;
  padding: 0 !important;
  list-style: none !important;
  text-align: left !important;
}

body.woocommerce-cart .cart-collaterals ul#shipping_method li {
  margin: 0 0 6px !important;
  padding: 0 !important;
}

body.woocommerce-cart .cart-collaterals ul#shipping_method li:last-child {
  margin-bottom: 0 !important;
}

body.woocommerce-cart .cart-collaterals ul#shipping_method label {
  text-align: left;
}

body.woocommerce-cart .cart-collaterals ul#shipping_method li {
  display: flex !important;
  flex-wrap: nowrap;
  align-items: flex-start;
  gap: 8px !important;
}

body.woocommerce-cart .cart-collaterals ul#shipping_method li input[type="radio"] {
  margin: 0.35em 0 0 !important;
  flex-shrink: 0;
}

body.woocommerce-cart .cart-collaterals ul#shipping_method li label {
  flex: 1;
  display: flex !important;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  font-weight: 500;
}

body.woocommerce-cart .cart-collaterals ul#shipping_method .woocommerce-Price-amount {
  font-weight: 700;
  white-space: nowrap;
  color: var(--brown);
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping td p:empty {
  display: none !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping form {
  margin: 0 !important;
}

body.woocommerce-cart .cart-collaterals .shipping-calculator-form {
  margin: 8px 0 0 !important;
  padding: 10px 6px 10px 0 !important;
  max-height: min(260px, 48vh);
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  border-top: 1px solid rgba(5, 16, 57, 0.08);
  scrollbar-gutter: stable;
}

body.woocommerce-cart .cart-collaterals .shipping-calculator-form .form-row,
body.woocommerce-cart .cart-collaterals .shipping-calculator-form p {
  margin: 0 0 8px !important;
  padding: 0 !important;
}

body.woocommerce-cart .cart-collaterals .shipping-calculator-form .form-row:last-of-type {
  margin-bottom: 0 !important;
}

body.woocommerce-cart .cart-collaterals .shipping-calculator-form select,
body.woocommerce-cart .cart-collaterals .shipping-calculator-form .input-text,
body.woocommerce-cart .cart-collaterals .shipping-calculator-form input[type="text"] {
  width: 100% !important;
  max-width: 100%;
  min-height: 42px;
  margin: 4px 0 0 !important;
  border: 1px solid var(--wc-card-border, rgba(5, 16, 57, 0.14));
  border-radius: 10px;
  padding: 10px 12px;
  font: var(--body-s);
  box-sizing: border-box;
}

body.woocommerce-cart .cart-collaterals .shipping-calculator-form button.button {
  width: 100% !important;
  display: block !important;
  margin: 12px 0 0 !important;
  min-height: 46px;
  border-radius: 999px !important;
  border: 0 !important;
  padding: 12px 22px !important;
  font: var(--body-btn) !important;
  color: var(--white) !important;
  background: var(--blue) !important;
  box-shadow: 0 6px 16px rgba(4, 157, 191, 0.26);
  cursor: pointer;
  box-sizing: border-box;
}

body.woocommerce-cart .cart-collaterals .shipping-calculator-form button.button:hover {
  background: #0389a6 !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping button[type="submit"],
body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping .shipping-calculator-form button,
body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping input.button {
  width: 100% !important;
  display: block !important;
  margin: 10px 0 0 !important;
  min-height: 46px;
  border-radius: 999px !important;
  border: 0 !important;
  padding: 12px 22px !important;
  font: var(--body-btn) !important;
  color: var(--white) !important;
  background: var(--blue) !important;
  box-shadow: 0 6px 16px rgba(4, 157, 191, 0.26);
  cursor: pointer;
  box-sizing: border-box;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping td label:not(.woocommerce-form__label-for-checkbox) {
  display: block;
  margin: 0 0 4px;
  font: var(--body-s);
  color: rgba(13, 13, 13, 0.75);
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping .select2-container {
  width: 100% !important;
  margin-top: 2px !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping .select2-container .select2-selection--single {
  min-height: 42px;
  border: 1px solid var(--wc-card-border, rgba(5, 16, 57, 0.14));
  border-radius: 10px;
  padding: 6px 10px;
  box-sizing: border-box;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.shipping .select2-container .select2-selection__rendered {
  line-height: 28px;
  padding-left: 0;
}

body.woocommerce-cart .cart-collaterals .order-total th,
body.woocommerce-cart .cart-collaterals .order-total td {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

body.woocommerce-cart .cart-collaterals .order-total td {
  color: var(--brown);
  font: 700 20px/1.2 "DM Sans", sans-serif;
}

body.woocommerce-cart .cart-collaterals .wc-proceed-to-checkout {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(5, 16, 57, 0.1);
}

body.woocommerce-cart .cart-collaterals .wc-proceed-to-checkout > * + * {
  margin-top: 10px;
}

body.woocommerce-cart .cart-collaterals #wc-stripe-payment-request-wrapper + .wc-proceed-to-checkout,
body.woocommerce-cart .cart-collaterals .wcpay-express-checkout-wrapper + .wc-proceed-to-checkout {
  margin-top: 12px;
  padding-top: 12px;
}

/* ============================================================
   DESKTOP (≥ 992px)
   ============================================================ */
@media (min-width: 992px) {
  body.woocommerce-cart .woocommerce {
    display: grid;
    grid-template-columns: minmax(0, 1.38fr) minmax(340px, 1fr);
    gap: clamp(18px, 3vw, 36px);
    align-items: start;
  }

  body.woocommerce-cart .woocommerce-cart-form,
  body.woocommerce-cart .cart-collaterals {
    margin: 0 !important;
  }

  body.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper {
    grid-column: 1 / -1;
  }

  body.woocommerce-cart .woocommerce > .woocommerce-cart-form {
    grid-column: 1;
  }

  body.woocommerce-cart .woocommerce > .cart-collaterals {
    grid-column: 2;
  }

  body.woocommerce-cart .cart-collaterals {
    margin-top: 0;
    position: sticky;
    top: 138px;
    align-self: start;
  }

  body.woocommerce-cart .woocommerce-cart-form {
    align-self: start;
  }
}

/* ============================================================
   TABLET + MOBILE (≤ 991px)
   Original WooCommerce stacked layout preserved.
   Fixes only: thumbnail visible, overflow not clipped, button widths.
   ============================================================ */
@media (max-width: 991px) {

  body.woocommerce-cart .woocommerce {
    display: block;
  }

  body.woocommerce-cart .cart-collaterals {
    position: static;
    top: auto;
  }

  body.woocommerce-cart .woocommerce-cart-form,
  body.woocommerce-cart .cart-collaterals {
    width: 100%;
    overflow: visible !important;
    box-sizing: border-box;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table {
    width: 100% !important;
    box-sizing: border-box;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table thead {
    display: none;
  }

  /* ── ITEM ROWS ──
     2-col grid: [thumbnail] [everything else stacked]
     Keeps WooCommerce's original stacked label order intact.          */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr.cart_item {
    display: grid !important;
    grid-template-columns: 88px 1fr;
    gap: 4px 14px;
    border-bottom: 1px solid rgba(5, 16, 57, 0.1);
    padding: 16px 0;
    width: 100%;
    box-sizing: border-box;
    align-items: start;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr.cart_item td {
    border-top: 0 !important;
    padding: 0 !important;
    min-width: 0;
  }

  /* Col 1 — thumbnail spans all rows */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-thumbnail {
    grid-column: 1;
    grid-row: 1 / span 6;
    display: flex;
    align-items: flex-start;
    padding-top: 2px;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-thumbnail img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid rgba(5, 16, 57, 0.1);
    background: #fff;
    padding: 3px;
    box-sizing: border-box;
    display: block;
  }

  /* Col 2 — all cells stack naturally in original WooCommerce order */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-remove,
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-name,
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-price,
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-quantity,
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-subtotal {
    grid-column: 2;
    width: 100%;
    text-align: left !important;
  }

  /* Remove button: push to right */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-remove {
    display: flex;
    justify-content: flex-end;
  }

  /* Quantity input: compact, never stretches */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-quantity .qty {
    width: 90px !important;
    min-width: 0 !important;
    max-width: 90px !important;
    min-height: 40px !important;
    box-sizing: border-box;
  }

  /* ── ACTIONS ROW ──
     WooCommerce renders .actions as a <td colspan="6"> in its own <tr>.
     When cart_item rows are display:grid, that tr inherits grid context.
     Force it back to block so it fills full card width.                */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr:has(td.actions),
  body.woocommerce-cart .woocommerce-cart-form table.shop_table tfoot tr {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.actions {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 0 !important;
  }

  body.woocommerce-cart .actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding-top: 16px !important;
  }

  body.woocommerce-cart .actions .coupon {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    box-sizing: border-box !important;
  }

  body.woocommerce-cart .actions .coupon .input-text {
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.woocommerce-cart .actions .coupon button.button,
  body.woocommerce-cart .actions > button.button {
    width: 100% !important;
    display: block !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    text-align: center !important;
  }

  body.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button {
    width: 100%;
    text-align: center;
  }
	
	 /* ✅ Proper spacing between elements */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr.cart_item {
    gap: 6px 14px !important;
    padding: 16px 0 !important;
    position: relative;
  }

  /* ✅ Move remove button to top-right corner */
  body.woocommerce-cart td.product-remove {
    position: absolute;
    top: 10px;
    right: 0;
    display: flex !important;
    justify-content: flex-end;
  }

  /* ✅ Add spacing for content so it doesn't overlap with remove btn */
  body.woocommerce-cart td.product-name {
    padding-right: 40px !important;
  }

  /* ✅ Restore labels like Quantity */
  body.woocommerce-cart td.product-quantity::before {
    content: "Quantity:";
    display: block;
    font-size: 12px;
    color: #777;
    margin-bottom: 4px;
  }

  body.woocommerce-cart td.product-price::before {
    content: "Price:";
    display: block;
    font-size: 12px;
    color: #777;
    margin-bottom: 2px;
  }

  body.woocommerce-cart td.product-subtotal::before {
    content: "Subtotal:";
    display: block;
    font-size: 12px;
    color: #777;
    margin-bottom: 2px;
  }

  /* ✅ Better spacing between stacked content */
  body.woocommerce-cart td.product-name,
  body.woocommerce-cart td.product-price,
  body.woocommerce-cart td.product-quantity,
  body.woocommerce-cart td.product-subtotal {
    margin-bottom: 4px !important;
  }

  /* ✅ Remove last item border */
  body.woocommerce-cart table.shop_table tbody tr.cart_item:last-child {
    border-bottom: none !important;
  }
	
	body.woocommerce-cart td.product-quantity {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start;
    gap: 4px;
  }

  body.woocommerce-cart td.product-quantity .qty {
    display: block;
    margin-top: 2px;
  }
	
	body.woocommerce-cart table.shop_table_responsive td.product-thumbnail::before {
    content: none !important;
    display: none !important;
  }

  /* Also ensure no list-style sneaks in */
  body.woocommerce-cart table.shop_table_responsive {
    list-style: none !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr,
  body.woocommerce-cart table.shop_table_responsive td {
    list-style: none !important;
  }
	
}

/* ============================================================
   MOBILE (≤ 768px) — tighten sizes, keep totals table intact
   ============================================================ */
@media (max-width: 768px) {
  body.woocommerce-cart > main {
    margin-top: 140px;
  }

  body.woocommerce-cart .woocommerce-cart-form,
  body.woocommerce-cart .cart-collaterals {
    border-radius: 12px;
    padding: 14px;
    overflow: visible !important;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr.cart_item {
    grid-template-columns: 76px 1fr;
    gap: 4px 12px;
    padding: 14px 0;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-thumbnail img {
    width: 72px;
    height: 72px;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-quantity .qty {
    width: 80px !important;
    max-width: 80px !important;
    min-height: 38px !important;
  }

  /* Totals card stays a real table — never touch its rows */
  body.woocommerce-cart .cart-collaterals .cart_totals table.shop_table.shop_table_responsive tbody tr,
  body.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tbody tr {
    display: table-row !important;
  }

  body.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tbody th,
  body.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tbody td {
    display: table-cell !important;
    width: auto;
  }
	
	.woocommerce table.shop_table_responsive tr td, .woocommerce-page table.shop_table_responsive tr td{
		text-align: left !important;
	}
	
	.newsletter-form .wpcf7-submit{
		margin-top: 12px;
        width: 100%;
	}
}

/* ============================================================
   SMALL MOBILE (≤ 640px)
   ============================================================ */
@media (max-width: 640px) {
  body.woocommerce-cart .container-inner,
  body.woocommerce-cart .woocommerce {
    padding-left: 16px;
    padding-right: 16px;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr.cart_item {
    grid-template-columns: 64px 1fr;
    gap: 4px 10px;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-thumbnail img {
    width: 60px;
    height: 60px;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-name a {
    font: var(--body-s);
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-price,
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-subtotal {
    font: 700 14px/1.3 "DM Sans", sans-serif;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-quantity .qty {
    width: 72px !important;
    max-width: 72px !important;
    min-height: 36px !important;
  }

  body.woocommerce-cart .cart-collaterals .cart_totals h2 {
    font: var(--h6);
  }
}

/* ============================================================
   EXTRA SMALL (≤ 480px)
   ============================================================ */
@media (max-width: 480px) {
  body.woocommerce-cart > main {
    margin-top: 128px;
  }

  body.woocommerce-cart .woocommerce-cart-form,
  body.woocommerce-cart .cart-collaterals {
    padding: 12px;
    border-radius: 10px;
    overflow: visible !important;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr.cart_item {
    grid-template-columns: 56px 1fr;
    gap: 4px 10px;
    padding: 12px 0;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-thumbnail img {
    width: 52px;
    height: 52px;
    border-radius: 8px;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-price,
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-subtotal {
    font: 700 13px/1.3 "DM Sans", sans-serif;
  }

  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-quantity .qty {
    width: 64px !important;
    max-width: 64px !important;
    min-height: 34px !important;
  }

  body.woocommerce-cart .actions .coupon .input-text,
  body.woocommerce-cart .actions button.button,
  body.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button {
    padding: 10px 16px !important;
    font: var(--body-text) !important;
  }

  body.woocommerce-cart .cart-collaterals .cart_totals .shop_table th,
  body.woocommerce-cart .cart-collaterals .cart_totals .shop_table td {
    padding: 8px 0 !important;
    font: var(--body-s);
  }

  body.woocommerce-cart .cart-collaterals .cart_totals .shop_table tbody th {
    padding-right: 8px !important;
  }

  body.woocommerce-cart .cart-collaterals .cart_totals .shop_table tbody td {
    padding-left: 8px !important;
  }
}