/* Tazers WooCommerce overrides. Brand-locked surfaces for shop archive,
   single product, cart, checkout, and my-account.
   See docs/design-plan.md §3.7 + §3.8. */

/* ============================================================
 * Break out of Hello Elementor's parent container.
 * Hello wraps content in #primary.content-area > main#main.site-main with
 * its own max-width + padding. We need our .tz-wc-wrap to be full-bleed so
 * the dark background reaches the viewport edges, then .tz-container handles
 * the 1440px centering inside.
 * ============================================================ */
body.woocommerce #primary,
body.woocommerce-page #primary,
body.woocommerce #main,
body.woocommerce-page #main,
body.woocommerce .site-main,
body.woocommerce-page .site-main,
body.woocommerce .content-area,
body.woocommerce-page .content-area {
  max-width: none !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ============================================================
 * Outer container (injected by tazers_wc_wrapper_start in functions.php)
 * Full-bleed dark wash; .tz-container inside handles the 1440px max-width.
 * ============================================================ */
.tz-wc-wrap {
  background: var(--tz-black);
  color: var(--tz-cream);
  padding: var(--space-7) 0 var(--space-9);
  /* Take up most of the viewport so short pages (empty cart, my-account) don't
     leave a big black void above the footer marquee.
     Math: viewport - header (60px) - footer marquee (~240px). */
  min-height: 70vh;                                      /* mobile baseline */
  width: 100%;
}
@media (min-width: 900px) {
  .tz-wc-wrap { min-height: calc(100vh - 60px - 240px); } /* desktop tight */
}

/* ============================================================
 * BLANKET LINK + BUTTON HOVER OVERRIDES on every WC surface.
 * The base.css <a>:hover uses --color-link-hover which defaults to cobalt
 * (blue) - that bleeds into WC links by inheritance. Force cream/red here
 * so no link or button on a WC page ever goes blue.
 * ============================================================ */
.tz-wc-wrap a:hover,
.tz-wc-wrap a:focus {
  color: var(--tz-red);
}
.tz-wc-wrap a.button:hover,
.tz-wc-wrap a.button:focus,
.tz-wc-wrap button.button:hover,
.tz-wc-wrap button.button:focus,
.tz-wc-wrap input.button:hover,
.tz-wc-wrap input.button:focus,
.tz-wc-wrap .checkout-button:hover,
.tz-wc-wrap .checkout-button:focus,
.tz-wc-wrap #place_order:hover,
.tz-wc-wrap #place_order:focus,
.tz-wc-wrap .single_add_to_cart_button:hover,
.tz-wc-wrap .single_add_to_cart_button:focus {
  text-decoration: none !important;
  color: var(--tz-red) !important;
  background: var(--tz-cream) !important;
  border-color: var(--tz-red) !important;
  outline: none !important;
}
/* Plain anchor links inside content / tables - keep red text, no underline shift */
.tz-wc-wrap .product-name a,
.tz-wc-wrap .product-name a:hover,
.tz-wc-wrap .woocommerce-breadcrumb a,
.tz-wc-wrap .woocommerce-breadcrumb a:hover {
  text-decoration: none;
}

/* On non-dark surfaces (cart/checkout/account pages can feel cleaner light)
   we flip to cream. Currently keep everything dark for visual unity. */

/* ============================================================
 * Shop intro
 * ============================================================ */
.tz-shop-intro {
  text-align: center;
  padding: var(--space-6) 0 var(--space-7);
  margin: 0 0 var(--space-6);
  border-bottom: 1px solid rgba(229,26,26,0.2);
}
.tz-shop-intro__heading {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(40px, 6vw, 80px);
  line-height: 1;
  letter-spacing: -0.02em;
  margin: var(--space-3) 0 var(--space-3);
}
.tz-shop-intro__lede {
  font-size: var(--fs-body-lg);
  max-width: 50ch;
  margin: 0 auto var(--space-3);
  color: rgba(245,239,226,0.85);
}
.tz-shop-intro__region {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(245,239,226,0.45);
}
.tz-shop-intro__region a { color: var(--tz-red); text-decoration: none; }
.tz-shop-intro__region a:hover { text-decoration: underline; }

/* ============================================================
 * Result count + sorting
 * ============================================================ */
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.08em;
  color: rgba(245,239,226,0.55);
  margin: 0 0 var(--space-5);
}
.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering { margin: 0 0 var(--space-5); }
.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
  background: var(--tz-black);
  border: 1px solid rgba(245,239,226,0.25);
  color: var(--tz-cream);
  padding: 10px 36px 10px 14px;
  font-family: var(--font-body);
  font-size: 14px;
}
.woocommerce .woocommerce-ordering select:focus,
.woocommerce-page .woocommerce-ordering select:focus {
  outline: 2px solid var(--tz-red);
  outline-offset: 2px;
  border-color: var(--tz-red);
}

/* ============================================================
 * SELECT - cross-cutting overrides for every WC <select>
 * Native <option> popup is browser-driven: Chrome/Firefox/Edge honor
 * background+color on the option element; Safari uses the OS popup and
 * will fall back to its default styling. The closed select still gets
 * brand styling (dark bg, cream text, red focus, custom red arrow).
 * ============================================================ */
.woocommerce select,
.woocommerce-page select,
.tz-wc-wrap select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: var(--tz-black);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--tz-red) 50%),
    linear-gradient(135deg, var(--tz-red) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  border: 1px solid rgba(245,239,226,0.25);
  color: var(--tz-cream);
  padding-right: 36px !important;
  cursor: pointer;
}
.woocommerce select:focus,
.woocommerce-page select:focus,
.tz-wc-wrap select:focus {
  outline: 2px solid var(--tz-red);
  outline-offset: 0;
  border-color: var(--tz-red);
}

/* The native popup - styled in Chrome / Firefox / Edge.
   Safari ignores these (uses OS-native popup). */
.woocommerce select option,
.woocommerce-page select option,
.tz-wc-wrap select option {
  background-color: var(--tz-black);
  color: var(--tz-cream);
  padding: 8px 12px;
}
.woocommerce select option:checked,
.woocommerce-page select option:checked,
.tz-wc-wrap select option:checked {
  background-color: var(--tz-red);
  color: var(--tz-cream);
  font-weight: 700;
}
.woocommerce select option:hover,
.woocommerce select option:focus,
.woocommerce-page select option:hover,
.woocommerce-page select option:focus {
  background-color: var(--tz-red);
  color: var(--tz-cream);
}

/* ============================================================
 * Shop archive - product grid
 * ============================================================ */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  list-style: none;
  margin: 0;
  padding: 0;
}
/* WooCommerce core adds ::before/::after clearfix pseudo-elements to
   ul.products. In a grid container those become phantom grid items and
   throw the product rows out of alignment - remove them. */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after { content: none; display: none; }
@media (min-width: 600px)  { .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px)  { .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); } }
@media (min-width: 1280px) { .woocommerce ul.products.columns-4, .woocommerce-page ul.products.columns-4 { grid-template-columns: repeat(4, 1fr); } }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  text-align: left;
  background: transparent;
  position: relative;
}
.woocommerce ul.products li.product a,
.woocommerce-page ul.products li.product a {
  display: block;
  color: var(--tz-cream);
  text-decoration: none;
  transition: transform var(--dur-base) var(--ease-out);
}
.woocommerce ul.products li.product:hover a { transform: translateY(-4px); }

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-display) !important;
  font-weight: 900 !important;
  font-size: 22px !important;
  line-height: 1.15 !important;
  letter-spacing: -0.01em;
  padding: var(--space-3) 0 var(--space-1) !important;
  margin: 0 !important;
  color: var(--tz-cream) !important;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  font-family: var(--font-mono) !important;
  font-size: 14px !important;
  color: var(--tz-red) !important;
  letter-spacing: 0.04em;
  margin: 0 !important;
}
.woocommerce ul.products li.product .price del,
.woocommerce-page ul.products li.product .price del {
  color: rgba(245,239,226,0.45) !important;
  margin-right: 8px;
}
.woocommerce ul.products li.product .price ins,
.woocommerce-page ul.products li.product .price ins {
  background: transparent !important;
  text-decoration: none !important;
  font-weight: 700;
}

/* Product thumb container */
.woocommerce ul.products li.product img,
.woocommerce-page ul.products li.product img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  object-fit: contain;
  padding: 12%;
  background: var(--tz-cream);
  aspect-ratio: 4 / 5;
  transition: transform var(--dur-slow) var(--ease-out), filter var(--dur-base) var(--ease-out);
}
.woocommerce ul.products li.product:hover img,
.woocommerce-page ul.products li.product:hover img {
  transform: scale(1.04);
  filter: contrast(1.05) saturate(1.1);
}

/* Add-to-cart button on archive cards */
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 10px 18px !important;
  background: var(--tz-red) !important;
  color: var(--tz-cream) !important;
  border: 2px solid var(--tz-red) !important;
  border-radius: var(--radius-button) !important;
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  margin: var(--space-3) 0 0 !important;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out) !important;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce-page ul.products li.product .button:hover {
  background: var(--tz-cream) !important;
  color: var(--tz-red) !important;
}
.woocommerce ul.products li.product .added_to_cart,
.woocommerce-page ul.products li.product .added_to_cart {
  display: inline-block;
  margin-top: var(--space-2) !important;
  margin-left: 12px !important;            /* breathing room from the ADD TO CART button */
  padding: 10px 18px;
  border: 2px solid var(--tz-red);
  color: var(--tz-red) !important;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.woocommerce ul.products li.product .added_to_cart:hover,
.woocommerce-page ul.products li.product .added_to_cart:hover {
  background: var(--tz-red);
  color: var(--tz-cream) !important;
}

/* Sale flash */
.woocommerce span.onsale,
.woocommerce-page span.onsale {
  position: absolute !important;
  top: 12px;
  left: 12px;
  background: var(--tz-red) !important;
  color: var(--tz-cream) !important;
  border-radius: 0 !important;
  font-family: var(--font-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase;
  font-weight: 700;
  padding: 6px 10px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  line-height: 1 !important;
  margin: 0 !important;
}

/* ============================================================
 * Single product
 * ============================================================ */
.woocommerce div.product,
.woocommerce-page div.product {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}
@media (min-width: 900px) {
  .woocommerce div.product,
  .woocommerce-page div.product { grid-template-columns: 1.1fr 1fr; gap: var(--space-8); }
}

.woocommerce div.product .woocommerce-product-gallery {
  width: 100% !important;
  float: none !important;
}
.woocommerce div.product .woocommerce-product-gallery img {
  background: var(--tz-cream);
  border: 1px solid rgba(245,239,226,0.1);
}
.woocommerce div.product .summary {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}
.woocommerce div.product .product_title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-3);
  color: var(--tz-cream);
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 32px !important;
  color: var(--tz-red) !important;
  margin: 0 0 var(--space-5) !important;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: var(--fs-body-lg);
  line-height: 1.55;
  color: rgba(245,239,226,0.85);
  margin: 0 0 var(--space-5);
}

/* Variations (size selectors etc.) */
.woocommerce div.product .variations { width: 100%; }
.woocommerce div.product .variations th,
.woocommerce div.product .variations td {
  background: transparent;
  padding: var(--space-2) 0;
}
.woocommerce div.product .variations label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tz-red);
}
.woocommerce div.product .variations select {
  background: transparent;
  border: 1px solid rgba(245,239,226,0.3);
  color: var(--tz-cream);
  padding: 12px 14px;
  font-family: var(--font-body);
  font-size: 14px;
  min-width: 160px;
}

/* Quantity stepper */
.woocommerce .quantity { display: inline-flex; align-items: center; }
.woocommerce .quantity input.qty {
  background: transparent !important;
  border: 1px solid rgba(245,239,226,0.3) !important;
  color: var(--tz-cream) !important;
  padding: 14px 12px !important;
  font-family: var(--font-mono) !important;
  font-size: 16px !important;
  width: 80px !important;
  text-align: center;
  height: auto !important;
}

/* Single product add-to-cart */
.woocommerce div.product form.cart {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  margin: var(--space-4) 0 var(--space-6);
}
.woocommerce div.product form.cart .button,
.woocommerce div.product .single_add_to_cart_button {
  flex: 1;
  min-width: 220px;
  padding: 16px 28px !important;
  background: var(--tz-red) !important;
  color: var(--tz-cream) !important;
  border: 2px solid var(--tz-red) !important;
  border-radius: var(--radius-button) !important;
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}
.woocommerce div.product form.cart .button:hover,
.woocommerce div.product .single_add_to_cart_button:hover {
  background: var(--tz-cream) !important;
  color: var(--tz-red) !important;
}

/* Product meta */
.woocommerce div.product .product_meta {
  border-top: 1px solid rgba(245,239,226,0.15);
  padding-top: var(--space-4);
  margin-top: var(--space-5);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: rgba(245,239,226,0.6);
}
.woocommerce div.product .product_meta a { color: var(--tz-red); text-decoration: none; }
.woocommerce div.product .product_meta a:hover { color: var(--tz-cream); }

/* Tabs */
.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1;
  margin-top: var(--space-7);
  border-top: 1px solid rgba(245,239,226,0.15);
  padding-top: var(--space-5);
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  list-style: none;
  padding: 0 !important;
  margin: 0 0 var(--space-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  border: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 12px 0 !important;
  color: var(--tz-cream) !important;
  font-family: var(--font-mono) !important;
  font-size: 12px !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase;
  border-bottom: 2px solid transparent;
  text-decoration: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  border-bottom-color: var(--tz-red);
  color: var(--tz-red) !important;
}
.woocommerce div.product .woocommerce-tabs .panel {
  background: transparent;
  font-size: 16px;
  line-height: 1.6;
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 28px;
  margin: 0 0 var(--space-3);
}

/* Related / upsells */
.woocommerce .related, .woocommerce .upsells, .woocommerce .cross-sells {
  grid-column: 1 / -1;
  margin-top: var(--space-8);
  border-top: 1px solid rgba(245,239,226,0.15);
  padding-top: var(--space-7);
}
.woocommerce .related h2, .woocommerce .upsells h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(24px, 3vw, 36px);
  margin: 0 0 var(--space-5);
}

/* ============================================================
 * Cart / Checkout / Account - tables
 * ============================================================ */
.woocommerce table.shop_table,
.woocommerce-page table.shop_table {
  background: transparent !important;
  border: 0 !important;
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  display: block;          /* allow horizontal scroll on overflow */
  overflow-x: auto;
}
@media (min-width: 600px) {
  .woocommerce table.shop_table,
  .woocommerce-page table.shop_table { display: table; overflow-x: visible; }
}
.woocommerce table.shop_table thead {
  background: transparent;
  border-bottom: 1px solid rgba(245,239,226,0.2);
}
.woocommerce table.shop_table th {
  background: transparent !important;
  font-family: var(--font-mono) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245,239,226,0.6) !important;
  border: 0 !important;
  padding: 14px 12px !important;
}
.woocommerce table.shop_table td {
  background: transparent !important;
  color: var(--tz-cream) !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(245,239,226,0.08) !important;
  padding: 18px 12px !important;
  vertical-align: middle;
}
.woocommerce table.shop_table tr:last-child td { border-bottom: 0 !important; }
/* Cart table - lock column widths so cells don't sprawl. Force table-layout
   fixed and set explicit widths via <colgroup>-style rules. */
body.woocommerce-cart table.shop_table.cart {
  table-layout: fixed;
  width: 100% !important;
}
body.woocommerce-cart table.shop_table.cart th.product-remove,
body.woocommerce-cart table.shop_table.cart td.product-remove {
  width: 36px !important;
  max-width: 36px !important;
  min-width: 36px !important;
  text-align: center !important;
  padding: 18px 4px !important;
}
body.woocommerce-cart table.shop_table.cart th.product-thumbnail,
body.woocommerce-cart table.shop_table.cart td.product-thumbnail {
  width: 100px !important;
  max-width: 100px !important;
  min-width: 100px !important;
  text-align: left !important;
  padding-left: 8px !important;
  padding-right: 12px !important;
}
body.woocommerce-cart table.shop_table.cart .product-thumbnail a,
body.woocommerce-cart table.shop_table.cart .product-thumbnail img {
  display: block !important;
  margin: 0 !important;
}
body.woocommerce-cart table.shop_table.cart th.product-name,
body.woocommerce-cart table.shop_table.cart td.product-name {
  width: auto !important;
  text-align: left !important;
  word-break: break-word;
}
body.woocommerce-cart table.shop_table.cart th.product-price,
body.woocommerce-cart table.shop_table.cart td.product-price {
  width: 80px !important;
  white-space: nowrap;
  text-align: right !important;
}
body.woocommerce-cart table.shop_table.cart th.product-quantity,
body.woocommerce-cart table.shop_table.cart td.product-quantity {
  width: 110px !important;
  text-align: center !important;
}
body.woocommerce-cart table.shop_table.cart th.product-subtotal,
body.woocommerce-cart table.shop_table.cart td.product-subtotal {
  width: 90px !important;
  text-align: right !important;
  white-space: nowrap;
}

/* Smaller screens - drop the price column, let things wrap */
@media (max-width: 640px) {
  body.woocommerce-cart table.shop_table.cart th.product-price,
  body.woocommerce-cart table.shop_table.cart td.product-price { display: none !important; }
  body.woocommerce-cart table.shop_table.cart th.product-thumbnail,
  body.woocommerce-cart table.shop_table.cart td.product-thumbnail {
    width: 70px !important; max-width: 70px !important; min-width: 70px !important;
  }
  body.woocommerce-cart table.shop_table.cart td.product-thumbnail img {
    width: 60px !important; height: 75px !important;
  }
}
.woocommerce table.shop_table .product-thumbnail img {
  width: 80px !important;
  height: 100px !important;
  object-fit: contain;
  background: var(--tz-cream);
  padding: 8%;
  border-radius: 0;
}
.woocommerce table.shop_table .product-name a {
  color: var(--tz-cream);
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 18px;
  text-decoration: none;
}
.woocommerce table.shop_table .product-name a:hover { color: var(--tz-red); }
.woocommerce table.shop_table .product-price,
.woocommerce table.shop_table .product-subtotal,
.woocommerce table.shop_table .product-total {
  font-family: var(--font-mono) !important;
  font-size: 14px !important;
  color: var(--tz-cream) !important;
}
.woocommerce a.remove {
  color: rgba(245,239,226,0.6) !important;
  font-weight: 400 !important;
  font-size: 22px !important;
  text-decoration: none !important;
}
.woocommerce a.remove:hover {
  background: transparent !important;
  color: var(--tz-red) !important;
}

/* ============================================================
 * Our injected H1 (replaces Hello Elementor's stripped entry-title).
 * Lives INSIDE the dark wrap so it inherits brand styling.
 * ============================================================ */
.tz-wc-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--tz-cream);
  text-align: center;
  margin: 0 0 var(--space-6);
}

/* Hide any orphan entry-title rendered by parent theme on WC pages, just in
   case the_title filter doesn't catch it (some themes render their own h1). */
body.woocommerce-cart .entry-header,
body.woocommerce-cart .page-header,
body.woocommerce-cart > .site-main > h1,
body.woocommerce-cart .entry-title:not(.tz-wc-title),
body.woocommerce-checkout .entry-header,
body.woocommerce-checkout .page-header,
body.woocommerce-checkout .entry-title:not(.tz-wc-title),
body.woocommerce-account .entry-header,
body.woocommerce-account .page-header,
body.woocommerce-account .entry-title:not(.tz-wc-title) {
  display: none !important;
}

/* ============================================================
 * CART PAGE - SINGLE centered column, stacked.
 * Cart items card above, totals card below, both max-width 720 centered.
 * ============================================================ */
body.woocommerce-cart .tz-wc-wrap .woocommerce {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  max-width: 720px;
  margin: 0 auto;
}

.woocommerce-cart-form,
.cart_totals, .woocommerce-cart .cart-collaterals { width: 100% !important; }

/* Cart items - boxed card */
.woocommerce-cart-form {
  background: rgba(245,239,226,0.03);
  border: 1px solid rgba(245,239,226,0.12);
  padding: var(--space-5);
}
@media (min-width: 600px) {
  .woocommerce-cart-form { padding: var(--space-6); }
}

/* Cart totals - red-tinted card */
.woocommerce-cart .cart-collaterals {
  display: block;
  margin: 0;
}
.woocommerce-cart .cart-collaterals .cart_totals {
  background: rgba(229,26,26,0.06);
  border: 1px solid rgba(229,26,26,0.3);
  padding: var(--space-5);
}
@media (min-width: 600px) {
  .woocommerce-cart .cart-collaterals .cart_totals { padding: var(--space-6); }
}
.woocommerce .cart_totals h2,
.woocommerce-cart .cart-collaterals h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(24px, 3vw, 32px);
  line-height: 1;
  margin: 0 0 var(--space-4);
  color: var(--tz-cream);
}
.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
  padding: 12px 0 !important;
  border-bottom: 1px solid rgba(245,239,226,0.1) !important;
}
.woocommerce .cart_totals .order-total .amount {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 22px;
  color: var(--tz-red);
}

/* Proceed-to-checkout button */
.woocommerce .wc-proceed-to-checkout { padding: 0 !important; margin-top: var(--space-4); }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  display: block !important;
  width: 100% !important;
  background: var(--tz-red) !important;
  color: var(--tz-cream) !important;
  border: 2px solid var(--tz-red) !important;
  border-radius: var(--radius-button) !important;
  padding: 18px 28px !important;
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  text-decoration: none !important;
  box-shadow: none !important;
  transition: background var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out) !important;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:focus {
  background: var(--tz-cream) !important;
  color: var(--tz-red) !important;
  border-color: var(--tz-red) !important;
  text-decoration: none !important;
  outline: none !important;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:active {
  transform: translateY(1px);
}

/* Coupon row */
.woocommerce-cart-form .coupon {
  display: flex;
  gap: 8px;
  align-items: stretch;
  flex-wrap: wrap;
  margin-top: var(--space-3);
}
.woocommerce-cart-form .coupon label { display: none; }
.woocommerce-cart-form .coupon input[type="text"] {
  background: transparent !important;
  border: 1px solid rgba(245,239,226,0.3) !important;
  color: var(--tz-cream) !important;
  padding: 12px 14px !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  flex: 1;
  min-width: 180px;
}

/* Update cart + actions row */
.woocommerce-cart-form .actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding-top: var(--space-4) !important;
}
.woocommerce-cart-form .actions [name="update_cart"] {
  background: transparent !important;
  color: var(--tz-cream) !important;
  border: 1px solid rgba(245,239,226,0.3) !important;
}
.woocommerce-cart-form .actions [name="update_cart"]:hover {
  background: var(--tz-cream) !important;
  color: var(--tz-black) !important;
}

/* Empty-cart layout */
.woocommerce-cart .cart-empty {
  text-align: center;
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(28px, 4vw, 48px);
  padding: var(--space-9) 0 var(--space-5);
  color: var(--tz-cream);
}
.woocommerce-cart .return-to-shop {
  text-align: center;
  padding: var(--space-4) 0 var(--space-9);
}

/* ============================================================
 * Generic buttons (button.button, input.button)
 * ============================================================ */
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button,
.woocommerce-page button.button,
.woocommerce-page input.button,
.woocommerce-page a.button {
  background: var(--tz-red) !important;
  color: var(--tz-cream) !important;
  border: 2px solid var(--tz-red) !important;
  border-radius: var(--radius-button) !important;
  padding: 12px 22px !important;
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out) !important;
}
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button:hover {
  background: var(--tz-cream) !important;
  color: var(--tz-red) !important;
}

/* ============================================================
 * CHECKOUT PAGE - SINGLE centered column, stacked.
 * Customer details card above, order review + payment card below.
 * Both max-width 720, centered. No floats, no grid columns.
 * ============================================================ */
body.woocommerce-checkout .tz-wc-wrap .woocommerce {
  display: block;
  max-width: 720px;
  margin: 0 auto;
}
body.woocommerce-checkout form.checkout {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  max-width: 720px;
  margin: 0 auto;
}

/* Customer details - boxed card */
body.woocommerce-checkout form.checkout #customer_details {
  background: rgba(245,239,226,0.03);
  border: 1px solid rgba(245,239,226,0.12);
  padding: var(--space-5);
  margin: 0 !important;
  width: 100% !important;
}
@media (min-width: 600px) {
  body.woocommerce-checkout form.checkout #customer_details { padding: var(--space-6); }
}
body.woocommerce-checkout form.checkout #customer_details .col-1,
body.woocommerce-checkout form.checkout #customer_details .col-2 {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
}
body.woocommerce-checkout form.checkout #customer_details .woocommerce-billing-fields h3,
body.woocommerce-checkout form.checkout #customer_details .woocommerce-shipping-fields h3,
body.woocommerce-checkout form.checkout #customer_details .woocommerce-additional-fields h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 24px;
  margin: 0 0 var(--space-4);
  color: var(--tz-cream);
}

/* Order review heading + box */
body.woocommerce-checkout form.checkout #order_review_heading,
body.woocommerce-checkout form.checkout #order_review {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}
body.woocommerce-checkout form.checkout #order_review_heading {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(22px, 3vw, 28px);
  margin: 0 0 var(--space-3) !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  color: var(--tz-cream);
}
body.woocommerce-checkout form.checkout #order_review {
  background: rgba(229,26,26,0.06) !important;
  border: 1px solid rgba(229,26,26,0.3) !important;
  padding: var(--space-5) !important;
}
@media (min-width: 600px) {
  body.woocommerce-checkout form.checkout #order_review { padding: var(--space-6) !important; }
}
body.woocommerce-checkout form.checkout #order_review .shop_table {
  margin-bottom: var(--space-4) !important;
}
body.woocommerce-checkout form.checkout #order_review .order-total .amount {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 22px;
  color: var(--tz-red);
}

/* Checkout form rows - keep them clean */
.woocommerce-checkout #customer_details { margin-bottom: var(--space-6); }
.woocommerce form .form-row label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,239,226,0.7);
}
.woocommerce form .form-row input[type="text"],
.woocommerce form .form-row input[type="email"],
.woocommerce form .form-row input[type="password"],
.woocommerce form .form-row input[type="tel"],
.woocommerce form .form-row input[type="number"],
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: transparent !important;
  border: 1px solid rgba(245,239,226,0.25) !important;
  color: var(--tz-cream) !important;
  padding: 12px 14px !important;
  font-family: var(--font-body) !important;
  font-size: 16px !important;        /* 16px prevents iOS auto-zoom on focus */
  border-radius: 0 !important;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.woocommerce form .form-row input:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  outline: 2px solid var(--tz-red);
  outline-offset: 0;
  border-color: var(--tz-red) !important;
}

/* Place-order button - matches the cart's proceed-to-checkout treatment */
.woocommerce-checkout #place_order {
  display: block !important;
  width: 100% !important;
  background: var(--tz-red) !important;
  color: var(--tz-cream) !important;
  border: 2px solid var(--tz-red) !important;
  border-radius: var(--radius-button) !important;
  padding: 18px 28px !important;
  margin-top: var(--space-4) !important;
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out) !important;
}
.woocommerce-checkout #place_order:hover,
.woocommerce-checkout #place_order:focus {
  background: var(--tz-cream) !important;
  color: var(--tz-red) !important;
  outline: none !important;
}

/* Terms checkbox row */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  margin-top: var(--space-4);
}
.woocommerce-checkout .form-row.terms label {
  font-family: var(--font-body);
  font-size: 13px;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(245,239,226,0.85);
}

/* Checkout link styling - "have a coupon?", "login?", etc */
.woocommerce-checkout .woocommerce-form-coupon-toggle a,
.woocommerce-checkout .woocommerce-form-login-toggle a,
.woocommerce-checkout .showcoupon,
.woocommerce-checkout .showlogin {
  color: var(--tz-red);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.woocommerce-checkout .woocommerce-form-coupon-toggle a:hover,
.woocommerce-checkout .woocommerce-form-login-toggle a:hover,
.woocommerce-checkout .showcoupon:hover,
.woocommerce-checkout .showlogin:hover { color: var(--tz-cream); }

/* Payment methods */
.woocommerce-checkout #payment {
  background: transparent !important;
  border-radius: 0;
}
.woocommerce-checkout #payment ul.payment_methods {
  border: 0;
  padding: 0;
}
.woocommerce-checkout #payment ul.payment_methods li {
  background: rgba(245,239,226,0.04);
  padding: var(--space-4) !important;
  margin-bottom: var(--space-3) !important;
  border: 1px solid rgba(245,239,226,0.12);
  border-radius: 4px;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
  /* Two-row grid: [radio][label centered] / [payment_box span 2] */
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas:
    "radio label"
    "box   box";
  align-items: center;
  column-gap: var(--space-3);
}
.woocommerce-checkout #payment ul.payment_methods li:hover {
  border-color: rgba(229,26,26,0.4);
  background: rgba(245,239,226,0.06);
}
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
  grid-area: radio;
  width: 20px;
  height: 20px;
  margin: 0 !important;
  cursor: pointer;
  accent-color: var(--tz-red);
  flex-shrink: 0;
}
.woocommerce-checkout #payment ul.payment_methods li label {
  grid-area: label;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 !important;
  cursor: pointer;
  width: 100%;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--tz-cream);
}
.woocommerce-checkout #payment ul.payment_methods li > div.payment_box {
  grid-area: box;
  margin: var(--space-3) 0 0 !important;
}
.woocommerce-checkout #payment ul.payment_methods li label img,
.woocommerce-checkout #payment ul.payment_methods li img.yoco-payment-method-icon {
  display: inline-block !important;
  float: none !important;
  clear: none !important;
  vertical-align: middle;
  max-height: 26px;
  width: auto;
  margin: 0 2px;
  padding: 0;
}
.woocommerce-checkout #payment div.payment_box {
  background: var(--tz-shadow);
  color: var(--tz-cream);
  border: 0;
  padding: var(--space-3) var(--space-4);
  border-radius: 3px;
}
.woocommerce-checkout #payment div.payment_box::before {
  display: none !important;
}

/* ============================================================
 * My Account
 * ============================================================ */
.woocommerce-account .woocommerce-MyAccount-navigation {
  width: 100% !important;
  margin: 0 0 var(--space-6);
}
@media (min-width: 900px) {
  .woocommerce-account .woocommerce-MyAccount-navigation { width: 25% !important; float: left; margin: 0; padding-right: var(--space-6); }
  .woocommerce-account .woocommerce-MyAccount-content    { width: 75% !important; float: right; }
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid rgba(245,239,226,0.15);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid rgba(245,239,226,0.08);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 14px 0;
  color: var(--tz-cream);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover { color: var(--tz-red); }

/* ============================================================
 * Messages / notices
 * ============================================================ */
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error,
.woocommerce-page .woocommerce-message,
.woocommerce-page .woocommerce-info,
.woocommerce-page .woocommerce-error {
  background: rgba(229,26,26,0.08) !important;
  border-top: 3px solid var(--tz-red) !important;
  border-radius: 0;
  color: var(--tz-cream) !important;
  font-family: var(--font-body) !important;
  font-size: 14px;
  padding: var(--space-4) var(--space-5) !important;
  margin: 0 0 var(--space-5) !important;
  list-style: none;
}
.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-error::before { display: none !important; }
.woocommerce .woocommerce-error { background: rgba(255, 30, 30, 0.12) !important; }

/* ============================================================
 * Pagination
 * ============================================================ */
.woocommerce nav.woocommerce-pagination ul {
  border: 0 !important;
  display: inline-flex;
  gap: 4px;
}
.woocommerce nav.woocommerce-pagination ul li {
  border: 0 !important;
  margin: 0;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border-radius: 0 !important;
  background: transparent !important;
  border: 1px solid rgba(245,239,226,0.25) !important;
  color: var(--tz-cream) !important;
  font-family: var(--font-mono) !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--tz-red) !important;
  border-color: var(--tz-red) !important;
  color: var(--tz-cream) !important;
}

/* Breadcrumbs */
.woocommerce .woocommerce-breadcrumb {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245,239,226,0.5);
  margin: 0 0 var(--space-5);
}
.woocommerce .woocommerce-breadcrumb a { color: var(--tz-red); text-decoration: none; }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--tz-cream); }
