/* ============================================================
   Trees of Health — WooCommerce skin
   Maps WooCommerce's default markup onto the brand design system.
   ============================================================ */

/* Generic Woo button → brand .btn look */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #place_order {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--sans); font-weight: 700; font-size: 15px; letter-spacing: -0.01em;
  padding: 15px 28px; border-radius: var(--cta-radius);
  background: var(--accent); color: var(--on-accent);
  border: 1.5px solid transparent; line-height: 1; white-space: nowrap;
  transition: transform .25s cubic-bezier(.2,.8,.2,1), background .25s, box-shadow .25s, color .25s;
  text-shadow: none; box-shadow: none;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce #place_order:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); background: var(--accent); color: var(--on-accent); }
.woocommerce a.button.disabled, .woocommerce button.button:disabled, .woocommerce button.button:disabled[disabled] { opacity: .5; }
.woocommerce a.button.ghost, .woocommerce button.ghost { background: transparent; color: var(--text); border-color: var(--line); }

/* Cart badge must stay hidden when empty (beats .hdr__badge display:grid) */
.hdr__badge[hidden] { display: none !important; }

/* Price */
.woocommerce .price, .woocommerce div.product p.price, .woocommerce div.product span.price {
  color: var(--text); font-weight: 800; font-family: var(--sans);
}
.woocommerce .price del { color: var(--text-faint); font-weight: 600; opacity: 1; margin-right: 6px; }
.woocommerce .price ins { text-decoration: none; }

/* ---------- Shop / archive ---------- */
.toh-shop-hero { background: var(--surface); padding: clamp(46px, 6vw, 84px) 0 clamp(34px, 4vw, 56px); border-bottom: 1px solid var(--line); }
.toh-shop-hero .shop__h { font-size: clamp(38px, 6vw, 70px); letter-spacing: -0.03em; margin: 16px 0 18px; }
.toh-shop-hero .shop__lead { font-size: 16.5px; line-height: 1.55; color: var(--text-soft); max-width: 60ch; }

.woocommerce .woocommerce-result-count { color: var(--text-soft); font-size: 14px; margin: 0; }
.woocommerce .woocommerce-ordering { margin: 0; }
.woocommerce .woocommerce-ordering select {
  font-family: var(--sans); font-size: 14px; font-weight: 600; padding: 11px 16px; border-radius: 999px;
  border: 1.5px solid var(--line); background: var(--bg); color: var(--text); cursor: pointer;
}

/* Category filter chips (custom, output by archive template) */
.toh-shop-bar { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 28px 0 8px; flex-wrap: wrap; position: sticky; top: 72px; background: color-mix(in srgb, var(--bg) 90%, transparent); backdrop-filter: blur(12px); z-index: 20; }
.toh-cats { display: flex; gap: 10px; flex-wrap: wrap; }
.toh-cats .chip { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; border-radius: 999px; border: 1.5px solid var(--line); font-weight: 700; font-size: 14px; color: var(--text-soft); transition: all .2s; }
.toh-cats .chip em { font-style: normal; font-size: 11.5px; opacity: .6; }
.toh-cats .chip:hover { border-color: var(--accent); color: var(--text); }
.toh-cats .chip.is-on { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.toh-shop-sort { display: inline-flex; align-items: center; gap: 10px; font-size: 14px; color: var(--text-soft); }

/* Product grid: reuse .pgrid look on Woo's ul.products */
.woocommerce ul.products, .woocommerce-page ul.products {
  display: grid !important; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2vw, 28px);
  align-items: stretch; margin: 8px 0 0; padding: 0; list-style: none;
}
.woocommerce ul.products::before, .woocommerce ul.products::after { content: none !important; }
.woocommerce ul.products li.product {
  width: auto !important; margin: 0 !important; float: none !important; height: 100%; padding: 0;
}
.woocommerce ul.products li.product::before { content: none; }
.woocommerce ul.products li.product .pcard { height: 100%; }

/* Add-to-bag: compact centered pill (override the design's full-width default) */
.pcard__add {
  left: 50%; right: auto; width: auto;
  padding: 11px 24px; white-space: nowrap;
  transform: translateX(-50%) translateY(8px);
}
.pcard:hover .pcard__add { transform: translateX(-50%); }

/* AJAX add-to-cart states on the card button */
.pcard__add.loading { opacity: 1; }
.pcard__add.added { background: var(--accent); color: var(--on-accent); opacity: 1; transform: translateX(-50%); }
.pcard__media a.added_to_cart { display: none !important; }

/* Assurance row */
.toh-assure { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin: clamp(56px, 8vw, 100px) 0; padding-top: 44px; border-top: 1px solid var(--line); }
.toh-assure .assure { display: flex; gap: 16px; }
.toh-assure .assure strong { display: block; font-size: 16px; margin-bottom: 6px; }
.toh-assure .assure p { font-size: 14px; color: var(--text-soft); line-height: 1.5; }

/* ---------- Single product (PDP) ---------- */
.single-product div.product { margin: 0; }
.single-product .product .toh-pdp-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(30px, 5vw, 72px); align-items: start; }
.single-product .toh-pdp-gallery { position: sticky; top: 92px; }
.single-product .toh-pdp-gallery .onsale { display: none; }
.single-product .toh-pdp-packshot { border-radius: var(--r-lg); overflow: hidden; }
.single-product .toh-pdp-packshot .packshot { border-radius: var(--r-lg); }
.single-product .woocommerce-product-gallery { margin: 0; float: none; width: 100%; opacity: 1 !important; }
.single-product .woocommerce-product-gallery .flex-viewport,
.single-product .woocommerce-product-gallery figure,
.single-product .woocommerce-product-gallery img { border-radius: var(--r-lg); }
.single-product .woocommerce-product-gallery__wrapper { margin: 0; }
.single-product .flex-control-thumbs { display: flex; gap: 12px; margin: 14px 0 0; padding: 0; }
.single-product .flex-control-thumbs li { width: 84px; list-style: none; }
.single-product .flex-control-thumbs img { border-radius: var(--r-sm); border: 2px solid transparent; }
.single-product .flex-control-thumbs img.flex-active { border-color: var(--accent); }

.toh-pdp-summary { display: flex; flex-direction: column; gap: 14px; padding-top: 8px; }
.toh-pdp-summary .pdp__cat { font-size: 12.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; display: block; }
.single-product .product_title { font-size: clamp(30px, 4vw, 46px); letter-spacing: -0.02em; line-height: 1.02; margin: 0; }
.single-product div.product .woocommerce-product-rating { margin: 0; display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--text-soft); }
.single-product div.product .woocommerce-product-rating .star-rating { color: var(--accent); }
.toh-pdp-tagline,
.single-product .woocommerce-product-details__short-description {
  font-family: var(--serif); font-weight: 300; font-size: 19px; line-height: 1.45;
  color: var(--text-soft); font-style: italic; margin: 4px 0 4px;
}
.single-product .woocommerce-product-details__short-description p { margin: 0; }
/* Price acts as the bracketed "buybar" from the design */
.single-product div.product p.price,
.single-product div.product span.price { font-size: 28px; }
.single-product .toh-pdp-summary > p.price {
  padding: 14px 0; border-top: 1px solid var(--line); margin: 6px 0 0;
}
.single-product .toh-pdp-summary > .toh-pdp-sizewrap {
  padding-bottom: 14px; border-bottom: 1px solid var(--line); margin-top: 6px;
}
.toh-pdp-sizewrap { margin: 10px 0 2px; }
.toh-pdp-size { font-size: 13px; color: var(--text-faint); padding: 5px 12px; border: 1px solid var(--line); border-radius: 999px; }

.single-product form.cart { display: flex; gap: 12px; align-items: stretch; margin: 6px 0; }
.single-product form.cart .quantity { display: inline-flex; align-items: center; border: 1.5px solid var(--line); border-radius: var(--cta-radius); overflow: hidden; }
.single-product form.cart .quantity input.qty {
  width: 56px; height: 100%; border: none; background: transparent; color: var(--text);
  font-family: var(--sans); font-weight: 700; text-align: center; font-size: 15px;
}
.single-product form.cart button.single_add_to_cart_button { flex: 1; }

.toh-pdp-assure { display: flex; gap: 20px; flex-wrap: wrap; font-size: 13px; color: var(--text-soft); margin: 6px 0 4px; }
.toh-pdp-assure span { display: inline-flex; align-items: center; gap: 7px; }
.toh-pdp-origin { background: var(--surface); border-radius: var(--r-md); padding: 22px 24px; margin: 8px 0; }
.toh-pdp-origin .eyebrow { margin-bottom: 10px; }
.toh-pdp-origin p { font-family: var(--serif); font-weight: 300; font-size: 17px; line-height: 1.5; font-style: italic; color: var(--text); }

/* Branded rating row in the buy panel */
.toh-pdp-rating { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--text-soft); margin: 2px 0; }
.toh-pdp-rating .toh-stars { color: var(--accent); }

/* Tabs → brand look */
.woocommerce-tabs { margin-top: 8px; }
.woocommerce-tabs ul.tabs { padding: 0 !important; margin: 0 !important; display: flex; gap: 6px; border-bottom: 1px solid var(--line); list-style: none; }
.woocommerce-tabs ul.tabs::before, .woocommerce-tabs ul.tabs::after { content: none !important; border: none; }
.woocommerce-tabs ul.tabs li { background: none; border: none; border-radius: 0; margin: 0; padding: 0; list-style: none; }
.woocommerce-tabs ul.tabs li::marker { content: none; }
.woocommerce-tabs ul.tabs li::before, .woocommerce-tabs ul.tabs li::after { content: none !important; }
.woocommerce-tabs ul.tabs li a { padding: 13px 16px !important; font-weight: 700; font-size: 14px; color: var(--text-faint); border-bottom: 2px solid transparent; margin-bottom: -1px; display: block; }
.woocommerce-tabs ul.tabs li.active a { color: var(--text); border-color: var(--accent); }
.woocommerce-tabs .panel { padding: 22px 0; color: var(--text-soft); line-height: 1.65; font-size: 15.5px; }
.woocommerce-tabs .panel h2 { display: none; }
.toh-benefits { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.toh-benefits li { display: flex; align-items: center; gap: 12px; font-size: 15.5px; color: var(--text); }

/* Related products */
.single-product .related, .single-product .upsells { margin: clamp(56px, 8vw, 100px) 0; clear: both; }
.single-product .related > h2, .single-product .upsells > h2 { font-size: clamp(24px, 3vw, 38px); margin-bottom: 24px; letter-spacing: -0.02em; }

/* ---------- Notices ---------- */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews, p.no-comments {
  border-top: none; padding: 16px 20px 16px 22px; border-radius: var(--r-md);
  background: var(--surface); color: var(--text); font-size: 14.5px; box-shadow: none;
  border: 1px solid var(--line); display: flex; align-items: center; gap: 10px; list-style: none;
}
.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before { color: var(--accent); position: static; margin-right: 4px; }
.woocommerce-message { border-color: color-mix(in srgb, var(--accent) 45%, transparent); }
.woocommerce-error { border-color: color-mix(in srgb, var(--accent-2) 50%, transparent); flex-direction: column; align-items: flex-start; }

/* ---------- Forms (checkout / account / cart) ---------- */
.woocommerce form .form-row label, .woocommerce-checkout label { font-size: 13px; font-weight: 600; color: var(--text-soft); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="password"],
.woocommerce .select2-container--default .select2-selection--single,
.woocommerce select {
  font-family: var(--sans); font-size: 15px; padding: 13px 16px; border-radius: var(--r-sm);
  border: 1.5px solid var(--line); background: var(--surface-2); color: var(--text); line-height: 1.3;
}
.woocommerce .select2-container--default .select2-selection--single { height: auto; padding: 11px 16px; }
.woocommerce form .form-row input.input-text:focus,
.woocommerce-checkout input:focus, .woocommerce select:focus { outline: none; border-color: var(--accent); }

/* ---------- Cart page ---------- */
.woocommerce table.shop_table { border-collapse: separate; border-spacing: 0; border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--surface-2); margin-bottom: 28px; }
.woocommerce table.shop_table th { font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-soft); padding: 16px 18px; }
.woocommerce-cart table.cart td { padding: 18px; vertical-align: middle; border-top: 1px solid var(--line); }
.woocommerce-cart table.cart td.product-remove { width: 44px; text-align: center; }
.woocommerce-cart table.cart td.product-remove a.remove { display: inline-grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; color: var(--text-faint) !important; font-size: 14px; }
.woocommerce-cart table.cart td.product-remove a.remove:hover { background: var(--surface); color: var(--accent-2) !important; }
.woocommerce-cart table.cart td.product-thumbnail { width: 90px; }
.woocommerce-cart table.cart img { width: 72px; border-radius: var(--r-sm); }
.woocommerce-cart table.cart td.product-name a { font-weight: 700; color: var(--text); }
.woocommerce-cart table.cart td.product-name a:hover { color: var(--accent); }
.woocommerce-cart .product-quantity .quantity { border: 1.5px solid var(--line); border-radius: var(--cta-radius); display: inline-flex; overflow: hidden; }
.woocommerce-cart .product-quantity .quantity input.qty { width: 58px; padding: 10px 6px; border: none; background: transparent; text-align: center; font-weight: 700; font-family: var(--sans); color: var(--text); }
.woocommerce-cart table.cart td.actions { padding: 18px; background: var(--surface); border-top: 1px solid var(--line); }
.woocommerce-cart table.cart td.actions .coupon { display: inline-flex; gap: 10px; align-items: stretch; }
.woocommerce-cart table.cart td.actions .coupon input#coupon_code { padding: 13px 16px; border: 1.5px solid var(--line); border-radius: var(--r-sm); background: var(--surface-2); min-width: 180px; }
.woocommerce-cart table.cart td.actions > button[name="update_cart"] { float: right; }

/* Cart totals card */
.woocommerce .cart-collaterals { display: block; }
.woocommerce .cart-collaterals .cart_totals, .woocommerce-page .cart-collaterals .cart_totals { width: 100%; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 24px 26px; float: none; }
.woocommerce .cart_totals table.shop_table { width: 100%; border: none; background: transparent; margin: 0; }
.woocommerce .cart_totals table.shop_table th, .woocommerce .cart_totals table.shop_table td { padding: 12px 0; border-top: 1px solid var(--line); text-transform: none; font-size: 14.5px; color: var(--text-soft); vertical-align: middle; }
.woocommerce .cart_totals table.shop_table th { text-align: left; font-weight: 600; width: 40%; }
.woocommerce .cart_totals table.shop_table td { text-align: right; }
.woocommerce .cart_totals table.shop_table tr:first-child th, .woocommerce .cart_totals table.shop_table tr:first-child td { border-top: none; }
.woocommerce .cart_totals .order-total th { font-size: 16px; color: var(--text); }
.woocommerce .cart_totals .order-total td { font-size: 18px; color: var(--text); font-weight: 800; }
.woocommerce .cart_totals h2, .woocommerce-checkout #order_review_heading { font-size: 20px; margin-bottom: 14px; }
.woocommerce .cart_totals .wc-proceed-to-checkout { padding: 18px 0 0; }
.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button { width: 100%; }
.woocommerce-cart .cart-empty, .woocommerce-cart .return-to-shop { text-align: center; }

/* Cart page: table + totals side by side */
@media (min-width: 981px) {
  .woocommerce-cart .woocommerce { display: grid; grid-template-columns: 1.6fr 1fr; gap: clamp(28px, 4vw, 56px); align-items: start; }
  .woocommerce-cart .woocommerce > * { min-width: 0; }
  .woocommerce-cart .woocommerce > .woocommerce-notices-wrapper { grid-column: 1 / -1; }
  .woocommerce-cart .woocommerce-cart-form { grid-column: 1; margin: 0; }
  .woocommerce-cart .cart-collaterals { grid-column: 2; }
  .woocommerce-cart .cart-collaterals .cart_totals { position: sticky; top: 92px; }
}

/* ---------- Checkout layout ---------- */
.woocommerce-checkout .col2-set { float: none; width: 100%; }
@media (min-width: 981px) {
  /* Float layout so the order summary hugs the top-right regardless of form height. */
  .woocommerce-checkout form.checkout { display: block; }
  .woocommerce-checkout form.checkout::after { content: ""; display: block; clear: both; }
  .woocommerce-checkout form.checkout .col2-set { float: left; width: 58%; margin: 0; }
  .woocommerce-checkout form.checkout #order_review_heading { float: right; width: 38%; margin: 0 0 14px; }
  .woocommerce-checkout form.checkout #order_review { float: right; width: 38%; clear: right; position: sticky; top: 92px; }
}
.woocommerce-checkout #payment { background: var(--surface-2); border-radius: var(--r-md); border: 1px solid var(--line); padding: 6px 6px 0; margin-top: 10px; }
.woocommerce-checkout #payment ul.payment_methods { list-style: none; margin: 0; padding: 0; border: none; }
.woocommerce-checkout #payment ul.payment_methods li { list-style: none; padding: 16px 18px; border-bottom: 1px solid var(--line); margin: 0; }
.woocommerce-checkout #payment ul.payment_methods li::before, .woocommerce-checkout #payment ul.payment_methods li::after { content: none !important; }
.woocommerce-checkout #payment ul.payment_methods li:last-child { border-bottom: none; }
.woocommerce-checkout #payment ul.payment_methods li > label { display: inline-flex; align-items: center; gap: 9px; font-weight: 700; font-size: 14.5px; color: var(--text); margin: 0; line-height: 1.3; }
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] { width: 17px; height: 17px; margin: 0; accent-color: var(--accent); flex-shrink: 0; }
.woocommerce-checkout #payment ul.payment_methods li img { max-height: 24px; margin-left: 8px; }
.woocommerce-checkout #payment div.payment_box { background: var(--surface); border-radius: var(--r-md); padding: 18px 20px; margin: 14px 0 6px; font-size: 13.5px; line-height: 1.65; color: var(--text-soft); }
.woocommerce-checkout #payment div.payment_box p { margin: 0 0 10px; }
.woocommerce-checkout #payment div.payment_box p:last-child { margin-bottom: 0; }
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: var(--surface); left: 18px; }
.woocommerce-checkout #payment .woocommerce-privacy-policy-text { padding: 18px 18px 6px; font-size: 13px; line-height: 1.6; color: var(--text-faint); }
.woocommerce-checkout #payment .form-row.place-order { padding: 16px 18px 18px; margin: 0; }
.woocommerce-checkout #payment .wc-terms-and-conditions { padding: 0 18px; }
.woocommerce-checkout #order_review { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 24px 26px 26px; }
.woocommerce-checkout .woocommerce-checkout-payment { background: transparent; }

/* Order summary lines (match the design's .ckline) */
.toh-ck-table { display: block; width: 100%; }
.toh-ck-lines { display: flex; flex-direction: column; gap: 14px; padding-bottom: 18px; border-bottom: 1px solid var(--line); margin: 0; }
.toh-ckline { display: grid; grid-template-columns: 52px 1fr auto; gap: 12px; align-items: center; }
.toh-ckline__media { position: relative; width: 52px; }
.toh-ckline__media .toh-mini-pack { width: 52px; }
.toh-ckline__media img { width: 52px !important; height: 52px; object-fit: cover; border-radius: var(--r-sm); display: block; margin: 0; }
.toh-ckline__q { position: absolute; top: -6px; right: -6px; min-width: 20px; height: 20px; padding: 0 5px; border-radius: 10px; background: var(--accent); color: var(--on-accent); font-size: 11px; font-weight: 800; display: grid; place-items: center; }
.toh-ckline__info { display: flex; flex-direction: column; min-width: 0; gap: 1px; }
.toh-ckline__info span { font-size: 14px; font-weight: 600; line-height: 1.25; }
.toh-ckline__info em { font-style: normal; font-size: 12px; color: var(--text-faint); }
.toh-ckline__p { font-weight: 700; font-size: 14px; white-space: nowrap; }

/* Order summary totals */
.toh-ck-totals-table { width: 100%; border: none; background: transparent; margin: 14px 0 0; border-collapse: collapse; }
.toh-ck-totals-table th, .toh-ck-totals-table td { padding: 9px 0; border: none; font-size: 14.5px; color: var(--text-soft); vertical-align: top; }
.toh-ck-totals-table th { text-align: left; font-weight: 600; }
.toh-ck-totals-table td { text-align: right; }
.toh-ck-totals-table .order-total th, .toh-ck-totals-table .order-total td { padding-top: 14px; border-top: 1px solid var(--line); font-size: 18px; color: var(--text); }
.toh-ck-totals-table .order-total td { font-weight: 800; }
.toh-ck-totals-table .woocommerce-shipping-destination, .toh-ck-totals-table .shipping ul#shipping_method { font-size: 12.5px; color: var(--text-faint); font-weight: 400; list-style: none; margin: 6px 0 0; padding: 0; text-align: left; }
.toh-ck-totals-table .shipping ul#shipping_method li { margin: 4px 0; }
.toh-ck-seal { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--text-faint); margin: 16px 0 0; }

/* ---- Checkout/account form fields (WC default CSS is disabled, so lay them out) ---- */
.woocommerce-checkout h3, .woocommerce-account h3 { font-size: 20px; margin: 0 0 16px; letter-spacing: -0.01em; }
.woocommerce form .form-row { display: block; margin: 0 0 14px; padding: 0; }
.woocommerce form .form-row label { display: block; margin-bottom: 6px; }
.woocommerce form .form-row label.checkbox { display: inline-flex; align-items: center; gap: 8px; }
.woocommerce form .form-row .required { color: var(--accent-2); border: 0; text-decoration: none; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout .select2-container { width: 100% !important; box-sizing: border-box; }
.woocommerce form .form-row textarea { min-height: 100px; resize: vertical; }
.woocommerce .col2-set, .woocommerce-page .col2-set { width: 100%; }
.woocommerce .col2-set .col-1, .woocommerce .col2-set .col-2 { width: 100%; float: none; margin: 0; }

/* First/last name (and equivalents) sit side by side */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce-address-fields__field-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 0 16px; }
.woocommerce-billing-fields__field-wrapper > .form-row,
.woocommerce-shipping-fields__field-wrapper > .form-row,
.woocommerce-address-fields__field-wrapper > .form-row { grid-column: 1 / -1; }
.woocommerce-billing-fields__field-wrapper > .form-row-first,
.woocommerce-shipping-fields__field-wrapper > .form-row-first,
.woocommerce-address-fields__field-wrapper > .form-row-first { grid-column: 1; }
.woocommerce-billing-fields__field-wrapper > .form-row-last,
.woocommerce-shipping-fields__field-wrapper > .form-row-last,
.woocommerce-address-fields__field-wrapper > .form-row-last { grid-column: 2; }
.woocommerce-additional-fields__field-wrapper .form-row { grid-column: 1 / -1; }

/* Coupon toggle row */
.woocommerce-checkout .woocommerce-form-coupon-toggle { margin-bottom: 18px; }
.woocommerce form.checkout_coupon { border: 1px solid var(--line); border-radius: var(--r-md); padding: 20px; margin-bottom: 24px; }
.woocommerce-form-login-toggle + .woocommerce-form-login, .woocommerce form.login { border: 1px solid var(--line); border-radius: var(--r-md); padding: 20px; }

/* Stripe card field inside the payment box (rendered by the gateway) */
.woocommerce-checkout .wc-stripe-elements-field,
.woocommerce-checkout .wc-stripe-iban-element-field,
.woocommerce-checkout #wc-stripe-cc-form .form-row,
.woocommerce-checkout .StripeElement {
  background: var(--surface-2); border: 1.5px solid var(--line); border-radius: var(--r-sm); padding: 13px 16px;
}
.woocommerce-checkout .StripeElement--focus { border-color: var(--accent); }

/* ---------- Order received / thank-you ---------- */
.toh-thankyou { max-width: 780px; margin: 0 auto; }
.toh-thankyou__hero { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 14px; padding: clamp(16px, 3vw, 32px) 0 clamp(34px, 5vw, 54px); }
.toh-thankyou__hero .eyebrow { justify-content: center; }
.toh-thankyou__h { font-size: clamp(30px, 4.5vw, 50px); font-style: italic; letter-spacing: -0.01em; line-height: 1.05; }
.toh-thankyou__lead { font-size: 16px; color: var(--text-soft); max-width: 46ch; line-height: 1.6; margin: 2px 0 6px; }
.toh-thankyou__order { display: inline-flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 14px 26px; padding: 16px 28px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); margin: 6px 0 4px; }
.toh-thankyou__order span:not(.toh-thankyou__div) { font-size: 14px; color: var(--text-soft); }
.toh-thankyou__order strong { color: var(--text); font-weight: 800; }
.toh-thankyou__div { width: 1px; height: 18px; background: var(--line); }
.toh-thankyou__actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

.toh-thankyou__details { margin-top: 10px; }
.toh-thankyou__details h2 { font-size: 22px; letter-spacing: -0.01em; margin: 30px 0 14px; }
.toh-thankyou__details .woocommerce-order-details, .toh-thankyou__details .woocommerce-customer-details { margin: 0; }
.toh-thankyou__details table.order_details, .toh-thankyou__details table.woocommerce-table--order-details { width: 100%; border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--surface-2); border-collapse: separate; border-spacing: 0; }
.toh-thankyou__details table.order_details th, .toh-thankyou__details table.order_details td { padding: 14px 18px; border: none; border-top: 1px solid var(--line); }
.toh-thankyou__details table.order_details thead th { border-top: none; font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-soft); }
.toh-thankyou__details table.order_details td.product-total, .toh-thankyou__details table.order_details td.woocommerce-table__product-total { text-align: right; white-space: nowrap; }
.toh-thankyou__details table.order_details th.product-total { text-align: right; }
.toh-thankyou__details table.order_details tfoot th { text-align: left; font-weight: 600; color: var(--text-soft); }
.toh-thankyou__details table.order_details tfoot td { text-align: right; }
.toh-thankyou__details table.order_details tfoot tr:last-child th, .toh-thankyou__details table.order_details tfoot tr:last-child td { font-size: 17px; color: var(--text); }
.toh-thankyou__details table.order_details tfoot tr:last-child td { font-weight: 800; }
.toh-thankyou__details .woocommerce-columns--addresses { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 10px; }
.toh-thankyou__details .woocommerce-columns--addresses .woocommerce-column__title { font-size: 16px; margin: 0 0 10px; }
.toh-thankyou__details address { font-style: normal; font-size: 14.5px; line-height: 1.7; color: var(--text-soft); border: 1px solid var(--line); border-radius: var(--r-md); padding: 18px 20px; background: var(--surface); }
@media (max-width: 600px) { .toh-thankyou__details .woocommerce-columns--addresses { grid-template-columns: 1fr; } }

/* ---------- Breadcrumb ---------- */
.woocommerce-breadcrumb { font-size: 13px; color: var(--text-faint); margin: 24px 0 8px; }
.woocommerce-breadcrumb a { color: var(--text-soft); }
.woocommerce-breadcrumb a:hover { color: var(--accent); }

/* ---------- Mini-cart drawer ---------- */
.toh-drawer { position: fixed; inset: 0; z-index: 1000; pointer-events: none; visibility: hidden; }
.toh-drawer.open { visibility: visible; pointer-events: auto; }
.toh-drawer__scrim { position: absolute; inset: 0; background: rgba(10,55,60,.42); opacity: 0; transition: opacity .35s; }
.toh-drawer.open .toh-drawer__scrim { opacity: 1; }
.toh-drawer__panel { position: absolute; top: 0; right: 0; height: 100%; width: min(440px, 92vw); background: var(--bg); box-shadow: -20px 0 60px rgba(10,55,60,.18); transform: translateX(100%); transition: transform .4s cubic-bezier(.3,.9,.2,1); display: flex; flex-direction: column; }
.toh-drawer.open .toh-drawer__panel { transform: none; }
.toh-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 24px 26px; border-bottom: 1px solid var(--line); }
.toh-drawer__head h3 { font-size: 19px; display: flex; align-items: center; gap: 10px; }
.toh-drawer__head em { font-style: normal; font-size: 13px; font-weight: 700; color: var(--on-accent); background: var(--accent); border-radius: 999px; padding: 2px 9px; }
.toh-drawer__x { font-size: 16px; color: var(--text-soft); width: 36px; height: 36px; border-radius: 50%; }
.toh-drawer__x:hover { background: var(--surface); }
.toh-drawer__body { flex: 1; overflow-y: auto; display: flex; flex-direction: column; }

/* Style Woo's widget mini-cart inside the drawer */
.toh-drawer .widget_shopping_cart_content { display: flex; flex-direction: column; flex: 1; }
.toh-drawer ul.woocommerce-mini-cart, .toh-drawer ul.cart_list { flex: 1; overflow-y: auto; margin: 0; padding: 8px 30px 8px 26px; list-style: none; }
.toh-drawer ul.cart_list li.woocommerce-mini-cart-item { display: grid; grid-template-columns: 64px 1fr 24px; gap: 14px; padding: 16px 4px 16px 0; border-bottom: 1px solid var(--line); align-items: center; position: relative; }
.toh-mc-info { padding-right: 8px; }
/* defensive: if a stale/default fragment renders, keep the quantity off the edge */
.toh-drawer ul.cart_list li .quantity { font-size: 13px; color: var(--text-soft); margin-right: 8px; }
.toh-mc-media { width: 64px; }
.toh-mc-media img, .toh-mc-media .toh-mini-pack { width: 64px !important; height: 64px; border-radius: var(--r-sm); display: block; margin: 0; object-fit: cover; }
.toh-mc-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.toh-mc-name { font-weight: 700; font-size: 14.5px; color: var(--text); line-height: 1.25; }
.toh-mc-name:hover { color: var(--accent); }
.toh-mc-meta { font-size: 12px; color: var(--text-faint); }
.toh-mc-price { font-size: 13px; color: var(--text-soft); font-weight: 600; }
.toh-drawer ul.cart_list li .remove { position: static; align-self: start; justify-self: end; width: 24px; height: 24px; line-height: 22px; text-align: center; font-size: 14px; color: var(--text-faint) !important; border-radius: 50%; }
.toh-drawer ul.cart_list li .remove:hover { color: var(--accent-2) !important; background: var(--surface); }

/* Branded mini tile used as a cart/mini-cart thumbnail */
.toh-mini-pack {
  position: relative; display: grid; place-items: center;
  width: 64px; aspect-ratio: 1/1; border-radius: var(--r-sm); overflow: hidden;
  background: radial-gradient(120% 90% at 50% -10%, #0e4a4f 0%, var(--dark-forest) 55%, #06282c 100%);
}
.toh-mini-pack__rule { position: absolute; left: 16%; right: 16%; bottom: 20%; height: 1.5px; opacity: .7; }
.woocommerce-cart table.cart .toh-mini-pack { width: 72px; }
.toh-drawer .woocommerce-mini-cart__total { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 18px 26px 6px; border-top: 1px solid var(--line); font-size: 17px; margin: 0; }
.toh-drawer .woocommerce-mini-cart__total strong { font-size: 15px; font-weight: 600; color: var(--text-soft); }
.toh-drawer .woocommerce-mini-cart__total .amount { font-size: 19px; font-weight: 800; }

/* Buttons live outside any .woocommerce wrapper, so style them explicitly. */
.toh-drawer .woocommerce-mini-cart__buttons { display: flex; flex-direction: column; gap: 10px; padding: 14px 26px 24px; margin: 0; }
.toh-drawer .woocommerce-mini-cart__buttons a.button {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px; width: 100%;
  font-family: var(--sans); font-weight: 700; font-size: 15px; letter-spacing: -0.01em; line-height: 1;
  padding: 16px 28px; border-radius: var(--cta-radius); white-space: nowrap;
  border: 1.5px solid transparent; background: var(--accent); color: var(--on-accent);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, color .25s, border-color .25s;
}
.toh-drawer .woocommerce-mini-cart__buttons a.button:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
/* Checkout = primary, on top; View cart = ghost, below. */
.toh-drawer .woocommerce-mini-cart__buttons a.checkout { order: 0; }
.toh-drawer .woocommerce-mini-cart__buttons a.button:not(.checkout) {
  order: 1; background: transparent; color: var(--text); border-color: var(--line);
}
.toh-drawer .woocommerce-mini-cart__buttons a.button:not(.checkout):hover {
  border-color: var(--accent); color: var(--accent); box-shadow: none; transform: none;
}
.toh-drawer p.woocommerce-mini-cart__empty-message { padding: 40px 26px; text-align: center; color: var(--text-soft); }

/* Free-shipping progress bar inside drawer */
.toh-ship { padding: 16px 26px; background: var(--surface); }
.toh-ship__row { font-size: 13.5px; margin-bottom: 10px; }
.toh-ship__bar { height: 6px; border-radius: 6px; background: var(--line); overflow: hidden; }
.toh-ship__bar span { display: block; height: 100%; background: var(--accent); border-radius: 6px; transition: width .4s; }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .single-product .product .toh-pdp-grid { grid-template-columns: 1fr; }
  .single-product .woocommerce-product-gallery { position: static; }
  .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); }
  .toh-assure { grid-template-columns: 1fr; }
  .toh-shop-bar { position: static; }
}
@media (max-width: 600px) {
  .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: 1fr; }
}
