/* ===========================================================
   EASY WARE — WooCommerce stylesheet
   Standard WC markup styled to the Schematic Workshop brand.
   Design tokens come from home.css (loaded earlier).
   =========================================================== */

/* WRAPPER ------------------------------------------------ */
.ew-woo {
  padding-block: clamp(1rem, 3vw, 2rem) clamp(3rem, 6vw, 5rem);
  position: relative;
}
.ew-woo__crosshair {
  display: flex; justify-content: space-between; gap: 1rem;
  font-family: var(--ff-mono);
  font-size: 0.65rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-4);
  padding: 0.75rem var(--container-pad);
  border-bottom: 1px dashed var(--edge-2);
  margin-bottom: 1.5rem;
}

/* PAGE HEADERS ------------------------------------------- */
.woocommerce-products-header__title,
.woocommerce-page h1.entry-title,
.woocommerce-page .page-title,
.cart_page_title,
.checkout-page-title {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(2rem, 4.5vw, 3rem);
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
  margin-block: 0 1rem;
}
.term-description, .woocommerce-products-header p {
  font-size: 0.95rem;
  color: var(--ink-3);
  max-width: 640px;
  margin-bottom: 2rem;
}

/* TOOLBAR (count + ordering) ----------------------------- */
.woocommerce-result-count {
  font-family: var(--ff-mono);
  font-size: 0.78rem; letter-spacing: 0.04em;
  color: var(--ink-3);
  margin-block: 1rem;
}
.woocommerce-ordering { margin-bottom: 1.5rem; }
.woocommerce-ordering select {
  font-family: var(--ff-body);
  font-size: 0.9rem;
  padding: 0.55rem 2.25rem 0.55rem 0.9rem;
  background: var(--surface);
  border: 1px solid var(--ink);
  border-radius: 999px;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%230A0A0A' stroke-width='1.6'%3E%3Cpath d='m3 5 3 3 3-3'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  background-size: 12px;
  cursor: pointer;
}

/* PRODUCT GRID (archive) --------------------------------- */
.woocommerce ul.products,
.woocommerce-page ul.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 0 !important;
  margin: 0 0 2rem !important;
  padding: 0 !important;
  list-style: none;
  border-top: 1.5px solid var(--ink);
  border-left: 1.5px solid var(--ink);
}
/* WooCommerce ships clearfix `::before, ::after { content: " "; display: table }`
   on ul.products. Inside our grid container those pseudo-elements become
   grid items and steal the first + last cells, pushing real products one
   column to the right. Kill them. */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after,
ul.products::before,
ul.products::after {
  content: none !important;
  display: none !important;
}
/* Match the desktop rule's selectors so the media query has equal specificity
   and actually wins inside @media (per WC's `!important` rule above). */
@media (max-width: 920px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 640px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

ul.products li.product,
ul.products li.product.first,
ul.products li.product.last {
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: var(--surface);
  border-right: 1.5px solid var(--ink);
  border-bottom: 1.5px solid var(--ink);
  display: flex !important;
  flex-direction: column;
  position: relative;
  transition: background var(--t-fast);
  clear: none !important;
  float: none !important;
  text-align: left !important;
}
ul.products li.product:hover { background: var(--paper); }

/* product image */
ul.products li.product a img,
ul.products li.product img {
  margin: 0 !important;
  aspect-ratio: 1;
  object-fit: cover;
  background:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px),
    var(--paper);
  background-size: 18px 18px;
  border-bottom: 1px solid var(--edge);
  transition: transform var(--t-base);
  width: 100% !important;
  height: auto !important;
}
ul.products li.product:hover img { transform: scale(1.04); }

ul.products li.product .woocommerce-LoopProduct-link {
  display: flex; flex-direction: column;
  text-decoration: none !important;
  color: inherit;
  padding: 0;
}

/* product title */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2,
ul.products li.product h3 {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1rem !important;
  letter-spacing: -0.012em;
  line-height: 1.25;
  color: var(--ink);
  padding: 1rem 1rem 0.4rem !important;
  margin: 0 !important;
}

/* price */
ul.products li.product .price {
  padding: 0 1rem 0.4rem !important;
  margin: 0 !important;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.1rem !important;
  color: var(--ink) !important;
}
ul.products li.product .price del {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--ink-4);
  font-family: var(--ff-mono);
  margin-right: 0.45rem;
  text-decoration: line-through;
  opacity: 1;
}
ul.products li.product .price ins {
  text-decoration: none;
  color: var(--red) !important;
  font-weight: 700;
  background: transparent;
}
ul.products li.product .price .woocommerce-Price-amount { font-size: inherit; }

/* sale flash */
ul.products li.product .onsale,
.woocommerce span.onsale {
  background: var(--red) !important;
  color: white !important;
  font-family: var(--ff-mono);
  font-weight: 700;
  font-size: 0.7rem !important;
  letter-spacing: 0.04em;
  padding: 4px 8px !important;
  min-height: auto !important;
  min-width: auto !important;
  border-radius: 0 !important;
  line-height: 1.2 !important;
  border: 0 !important;
  text-transform: uppercase;
  position: absolute !important;
  top: 0 !important; right: 0 !important; left: auto !important;
  margin: 0 !important;
}

/* star rating */
ul.products li.product .star-rating {
  margin: 0 1rem 0.4rem !important;
  font-size: 0.85rem;
  color: var(--red);
}

/* add to cart button (loop) */
.woocommerce ul.products li.product .button,
ul.products li.product .button {
  display: flex !important;
  align-items: center; justify-content: center;
  gap: 0.4rem;
  margin: auto 1rem 1rem !important;
  padding: 0.7rem 1rem !important;
  background: var(--ink) !important;
  color: white !important;
  font-family: var(--ff-body);
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.005em;
  border-radius: 999px !important;
  border: 0 !important;
  text-transform: none !important;
  text-align: center;
  transition: background var(--t-fast), transform var(--t-fast);
}
.woocommerce ul.products li.product .button:hover {
  background: var(--red) !important;
  transform: translateY(-1px);
}
.woocommerce ul.products li.product .added_to_cart {
  display: inline-block;
  margin: 0 1rem 1rem !important;
  font-family: var(--ff-mono);
  font-size: 0.75rem; font-weight: 600;
  text-transform: uppercase;
  color: var(--red) !important;
  letter-spacing: 0.05em;
}
.woocommerce ul.products li.product .button.loading::after {
  font-family: WooCommerce;
  content: "\e01c";
  margin-left: 0.5em;
  animation: ew-spin 1s linear infinite;
}
@keyframes ew-spin { to { transform: rotate(1turn); } }

/* SINGLE PRODUCT --------------------------------------- */
.single-product .product {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  margin-bottom: 3rem;
  padding-block: 1.5rem;
}
@media (max-width: 880px) { .single-product .product { grid-template-columns: 1fr; } }

/* Anything below the gallery + summary row must span both columns,
   otherwise auto-placement drops them next to each other in row 2+. */
.single-product .product > .woocommerce-tabs,
.single-product .product > .related,
.single-product .product > .related.products,
.single-product .product > .upsells,
.single-product .product > .upsells.products,
.single-product .product > .cross-sells,
.single-product .product > .ew-related {
  grid-column: 1 / -1 !important;
}

.single-product .product .images,
.single-product .product .woocommerce-product-gallery {
  width: 100% !important;
  margin: 0 !important;
  border: 1.5px solid var(--ink);
  background:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px),
    var(--paper);
  background-size: 22px 22px;
  position: relative;
}
.woocommerce-product-gallery img {
  width: 100% !important;
  height: auto !important;
}
.flex-control-thumbs {
  display: flex; gap: 0.5rem;
  margin-top: 0.75rem !important;
  padding: 0 !important;
  list-style: none;
}
.flex-control-thumbs li {
  width: 64px !important; height: 64px !important;
  margin: 0 !important;
  border: 1px solid var(--edge);
}
.flex-control-thumbs li img.flex-active { border-color: var(--red); }

.single-product .product .summary {
  margin: 0 !important;
  width: 100% !important;
  display: flex; flex-direction: column;
  gap: 1.2rem;
}
.single-product .product .product_title {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(1.85rem, 4vw, 2.6rem);
  letter-spacing: -0.035em;
  line-height: 1.05;
  color: var(--ink);
  margin: 0 !important;
}
.single-product .product .summary .price {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2rem) !important;
  letter-spacing: -0.025em;
  margin: 0 !important;
  color: var(--ink) !important;
  display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: baseline;
}
.single-product .product .summary .price del {
  font-size: 1.1rem;
  color: var(--ink-4);
  font-family: var(--ff-mono);
  font-weight: 500;
}
.single-product .product .summary .price ins {
  text-decoration: none;
  color: var(--red) !important;
  background: transparent;
}
.single-product .product .summary .woocommerce-product-details__short-description {
  color: var(--ink-2);
  font-size: 1rem;
  line-height: 1.6;
  padding: 1rem 1.1rem;
  background: var(--paper-2);
  border-left: 3px solid var(--red);
}
.single-product .product .summary .woocommerce-product-details__short-description p { margin: 0; }

.single-product .product .stock {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--ff-mono);
  font-size: 0.8rem; font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.4rem 0.85rem;
  border-radius: 4px;
  align-self: flex-start;
}
.single-product .stock.in-stock { color: var(--green); background: rgba(26,127,55,0.08); }
.single-product .stock.out-of-stock { color: var(--red); background: var(--red-soft); }

.single-product .product .product_meta {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--ink-3);
  border-top: 1px solid var(--edge);
  padding-top: 1rem;
  display: flex; flex-direction: column; gap: 0.35rem;
}
.single-product .product .product_meta > span {
  display: flex; gap: 0.5rem;
}
.single-product .product .product_meta a { color: var(--red); }
.single-product .product .product_meta .sku_wrapper .sku {
  color: var(--ink); font-weight: 700; letter-spacing: 0.04em;
}

/* qty + add-to-cart */
.single-product form.cart {
  display: flex; gap: 0.75rem; align-items: stretch; flex-wrap: wrap;
  margin: 0 !important;
}
.single-product form.cart .quantity {
  display: flex; align-items: stretch;
  border: 1.5px solid var(--ink);
  border-radius: 999px;
  overflow: hidden;
  background: var(--surface);
}
.single-product form.cart .quantity input.qty {
  width: 64px;
  text-align: center;
  border: 0 !important;
  font-family: var(--ff-mono);
  font-weight: 700; font-size: 1rem;
  background: transparent;
  height: 48px;
  color: var(--ink);
}
.single-product form.cart .quantity input.qty::-webkit-inner-spin-button,
.single-product form.cart .quantity input.qty::-webkit-outer-spin-button { display: none; }
.single-product form.cart button.single_add_to_cart_button,
.single-product form.cart .single_add_to_cart_button {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.5rem;
  padding: 0 1.6rem !important;
  background: var(--red) !important;
  color: white !important;
  font-family: var(--ff-body);
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  border-radius: 999px !important;
  border: 0 !important;
  text-transform: none !important;
  height: 48px;
  letter-spacing: 0;
  transition: background var(--t-fast), transform var(--t-fast);
}
.single-product form.cart button.single_add_to_cart_button:hover {
  background: var(--red-deep) !important;
  transform: translateY(-1px);
}

/* tabs */
.woocommerce-tabs {
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1.5px solid var(--ink);
}
.woocommerce-tabs ul.tabs {
  display: flex; gap: 0;
  margin: 0 0 1.5rem !important;
  padding: 0 !important;
  list-style: none;
  border-bottom: 1px solid var(--edge);
}
.woocommerce-tabs ul.tabs::before { display: none !important; }
.woocommerce-tabs ul.tabs li {
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: 0 !important;
  border-radius: 0 !important;
}
.woocommerce-tabs ul.tabs li::before, .woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 0.85rem 1.25rem !important;
  margin-right: 0.5rem;
  font-family: var(--ff-display);
  font-weight: 600 !important;
  font-size: 1rem;
  letter-spacing: -0.01em;
  color: var(--ink-3) !important;
  border-bottom: 2px solid transparent;
  transform: translateY(1px);
  transition: color var(--t-fast), border-color var(--t-fast);
}
.woocommerce-tabs ul.tabs li a:hover { color: var(--ink) !important; }
.woocommerce-tabs ul.tabs li.active a {
  color: var(--ink) !important;
  border-color: var(--red);
}
.woocommerce-tabs .panel {
  font-size: 0.95rem;
  color: var(--ink-2);
  line-height: 1.65;
}
.woocommerce-tabs .panel h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -0.025em;
  margin-bottom: 1rem;
}
.woocommerce-tabs .panel table {
  width: 100%;
  border-collapse: collapse;
}
.woocommerce-tabs .panel table th,
.woocommerce-tabs .panel table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--edge);
  font-family: var(--ff-mono);
  font-size: 0.85rem;
  text-align: left;
}
.woocommerce-tabs .panel table th {
  background: var(--paper-2);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 0.75rem;
}

/* Related / up-sell — span full width below single product layout */
.woocommerce div.product .related.products,
.woocommerce div.product .upsells.products {
  clear: both !important;
  float: none !important;
  width: 100% !important;
  margin-top: clamp(2.5rem, 5vw, 4rem) !important;
  padding-top: 2rem !important;
  border-top: 1.5px solid var(--ink);
}
.woocommerce div.product .related.products ul.products,
.woocommerce div.product .upsells.products ul.products {
  width: 100% !important;
}

/* Branded section header (used by single-product/related.php override) */
.ew-related__head {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin: 0 0 1.75rem;
  max-width: 720px;
}
.ew-related__kicker {
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red);
}
.ew-related__title {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--ink);
  margin: 0 !important;
}
.ew-related__lede {
  font-family: var(--ff-body);
  font-size: 0.95rem;
  color: var(--ink-3);
  margin: 0;
  max-width: 56ch;
}

/* Plain WC heading fallback (when used outside our override) */
.woocommerce div.product .related.products > h2:not(.ew-related__title),
.woocommerce div.product .upsells.products > h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  letter-spacing: -0.03em;
  margin: 0 0 1.5rem !important;
  color: var(--ink);
}

/* CART PAGE -------------------------------------------- */
.woocommerce-cart { padding-block: 1rem 4rem; }

/* Header strip: "// KERANJANG · N ITEM" + "← Lanjut belanja"
   Sits as a child of the grid-ified .woocommerce wrapper, so we explicitly
   span both columns to avoid being squeezed into column 1. */
.ew-cart-strip {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.75rem 0 1.25rem;
  margin-bottom: 1.5rem;
  border-bottom: 1.5px solid var(--ink);
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  flex-wrap: wrap;
}
.ew-cart-strip__label { color: var(--ink); font-weight: 700; }
.ew-cart-strip__back {
  color: var(--ink-3);
  display: inline-flex; align-items: center; gap: 0.4rem;
  transition: color var(--t-fast), gap var(--t-fast);
}
.ew-cart-strip__back:hover { color: var(--red); gap: 0.6rem; }

/* 50:50 split layout — only when cart has items.
   Uses :has() so empty-cart still flows normally. */
body.woocommerce-cart .ew-woo > .container .woocommerce:has(.woocommerce-cart-form) {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 1fr);
  gap: clamp(1.5rem, 3vw, 2.5rem);
  align-items: start;
}
@media (max-width: 960px) {
  body.woocommerce-cart .ew-woo > .container .woocommerce:has(.woocommerce-cart-form) {
    grid-template-columns: 1fr !important;
  }
}

/* Form column: prevent grid blowout from long product names */
.woocommerce-cart .woocommerce-cart-form { min-width: 0; }
.woocommerce-cart .woocommerce-cart-form table.shop_table { margin: 0 !important; }

/* Notices (success / warnings) sit full-width above the split, never as
   their own grid item or they'd push the cart form into column 2. */
.woocommerce-cart .woocommerce-notices-wrapper {
  grid-column: 1 / -1;
}
.woocommerce-cart .woocommerce-notices-wrapper:empty {
  display: none;
}

/* Right column: collaterals stick on scroll, fill the cell, no top margin */
.woocommerce-cart .cart-collaterals {
  margin-top: 0 !important;
  width: 100% !important;
  position: sticky;
  top: clamp(1rem, 4vh, 5rem);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

/* Override WC's default float-based collaterals layout */
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals,
.woocommerce .cart-collaterals .cross-sells,
.woocommerce-page .cart-collaterals .cross-sells,
.woocommerce .cart-collaterals .shipping_calculator,
.woocommerce-page .cart-collaterals .shipping_calculator {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
}

/* Empty cart treatment */
.woocommerce-cart .cart-empty {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2rem);
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0 0 0.75rem !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}
.woocommerce-cart .cart-empty.woocommerce-info::before { display: none !important; }
.woocommerce-cart .return-to-shop {
  margin-top: 1.5rem !important;
}
.woocommerce-cart .return-to-shop a {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.85rem 1.5rem !important;
  background: var(--red) !important;
  color: white !important;
  border-radius: 999px;
  font-weight: 700;
  border: 0 !important;
  font-family: var(--ff-body);
}

/* TABLES (cart, order summary) ------------------------- */
.woocommerce table.shop_table,
.woocommerce-page table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  border: 1.5px solid var(--ink) !important;
  border-radius: 0 !important;
  font-family: var(--ff-body);
  margin: 0 0 1.5rem !important;
}
.woocommerce table.shop_table thead {
  background: var(--ink);
  color: white;
}
.woocommerce table.shop_table thead th {
  padding: 0.85rem 1rem !important;
  border: 0 !important;
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  color: white;
  text-align: left;
}
.woocommerce table.shop_table tbody tr,
.woocommerce-page table.shop_table tbody tr {
  border-bottom: 1px solid var(--edge);
}
.woocommerce table.shop_table tbody tr:last-child { border-bottom: 0; }
.woocommerce table.shop_table tbody td {
  padding: 1rem !important;
  border-top: 0 !important;
  font-size: 0.95rem;
  vertical-align: middle;
  background: var(--surface);
}
.woocommerce table.shop_table .product-thumbnail img {
  max-width: 80px;
  height: auto;
  border: 1px solid var(--edge);
}
.woocommerce table.shop_table .product-name {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: -0.01em;
}
.woocommerce table.shop_table .product-name a {
  color: var(--ink);
}
.woocommerce table.shop_table .product-name a:hover { color: var(--red); }
.woocommerce table.shop_table .product-price,
.woocommerce table.shop_table .product-subtotal {
  font-family: var(--ff-mono);
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--ink);
}
.woocommerce a.remove {
  display: inline-grid !important;
  place-items: center;
  width: 28px !important; height: 28px !important;
  background: var(--ink) !important;
  color: white !important;
  border-radius: 50%;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 700;
  text-decoration: none !important;
  transition: background var(--t-fast);
}
.woocommerce a.remove:hover {
  background: var(--red) !important;
  color: white !important;
}

/* qty input in cart */
.woocommerce .quantity input.qty {
  width: 76px;
  height: 40px;
  text-align: center;
  border: 1px solid var(--ink);
  border-radius: 4px;
  background: var(--surface);
  font-family: var(--ff-mono);
  font-weight: 600;
}

/* coupon + update buttons row */
.woocommerce .cart .actions {
  padding: 1rem !important;
  background: var(--paper-2) !important;
  border-bottom: 0 !important;
}
.woocommerce .cart .actions .coupon {
  display: flex; gap: 0.5rem; align-items: stretch;
}
.woocommerce .cart .actions .coupon input.input-text {
  width: 200px;
  padding: 0.65rem 1rem;
  border: 1px solid var(--ink);
  background: var(--surface);
  border-radius: 999px;
  font-family: var(--ff-mono);
}

/* generic WC button */
.woocommerce .button,
.woocommerce a.button,
.woocommerce-page .button,
.woocommerce-page a.button,
.woocommerce input.button[type="submit"],
.woocommerce button.button {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 1.5rem !important;
  font-family: var(--ff-body) !important;
  font-weight: 700 !important;
  font-size: 0.9rem !important;
  letter-spacing: -0.005em;
  border-radius: 999px !important;
  border: 1px solid var(--ink) !important;
  background: var(--surface) !important;
  color: var(--ink) !important;
  text-transform: none !important;
  text-shadow: none !important;
  transition: all var(--t-fast);
  cursor: pointer;
}
.woocommerce .button:hover,
.woocommerce a.button:hover,
.woocommerce-page .button:hover {
  background: var(--ink) !important;
  color: white !important;
}
.woocommerce .button.alt,
.woocommerce a.button.alt,
.woocommerce input.button.alt[type="submit"],
.woocommerce button.button.alt,
.woocommerce-page a.button.alt {
  background: var(--red) !important;
  color: white !important;
  border-color: var(--red) !important;
}
.woocommerce .button.alt:hover,
.woocommerce-page .button.alt:hover {
  background: var(--red-deep) !important;
  border-color: var(--red-deep) !important;
}

/* CART TOTALS ------------------------------------------ */
.cart_totals {
  background: var(--paper-2);
  border: 1.5px solid var(--ink);
  position: relative;
  overflow: hidden;
  padding: 0 !important;
}
/* Mono kicker pinned to the top-left corner */
.cart_totals::before {
  content: "// RINGKASAN";
  position: absolute;
  top: 0; left: 0;
  padding: 0.5rem 0.85rem;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--ff-mono);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  z-index: 1;
}
.cart_totals h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: -0.025em;
  line-height: 1;
  margin: 0 !important;
  padding: 2.5rem 1.5rem 1.25rem;
  border-bottom: 1px solid var(--edge);
  background: var(--surface);
}

/* Reset the inner shop_table so we can lay it out as a clean key-value list */
.cart_totals table.shop_table,
.cart_totals table.shop_table tbody,
.cart_totals table.shop_table tr,
.cart_totals table.shop_table th,
.cart_totals table.shop_table td {
  display: block !important;
  border: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  width: auto !important;
  text-align: left !important;
}
.cart_totals table.shop_table {
  margin: 0 !important;
  padding: 1.25rem 1.5rem !important;
  background: var(--surface) !important;
}
.cart_totals table.shop_table tr {
  display: grid !important;
  grid-template-columns: max-content 1fr;
  gap: 0.75rem 1rem;
  align-items: baseline;
  padding-block: 0.7rem !important;
  border-bottom: 1px dashed var(--edge-2) !important;
}
.cart_totals table.shop_table tr:last-child { border-bottom: 0 !important; }
.cart_totals table.shop_table th {
  font-family: var(--ff-mono);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  white-space: nowrap;
}
.cart_totals table.shop_table td {
  font-family: var(--ff-mono);
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--ink);
  text-align: right !important;
}

/* Total row — make it dramatic, full-width, strong */
.cart_totals .order-total {
  margin-top: 0.5rem;
  padding-top: 1rem !important;
  padding-bottom: 0.5rem !important;
  border-top: 1.5px solid var(--ink) !important;
  border-bottom: 0 !important;
}
.cart_totals .order-total th {
  font-family: var(--ff-display) !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--ink) !important;
}
.cart_totals .order-total td {
  font-family: var(--ff-display) !important;
  font-size: 1.65rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  color: var(--red) !important;
}
.cart_totals .order-total td .amount {
  font-family: var(--ff-display);
  font-weight: 800;
  color: var(--red);
}

/* Subtotal screen-reader text gets in the way of the grid layout */
.cart_totals .order-total .includes_tax,
.cart_totals .order-total small.includes_tax {
  grid-column: 1 / -1;
  font-family: var(--ff-mono);
  font-size: 0.7rem;
  color: var(--ink-3);
  text-align: right;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Shipping cell — radio list + address + change-link */
.cart_totals .shipping td { text-align: left !important; }
.cart_totals .woocommerce-shipping-totals.shipping {
  grid-template-columns: max-content 1fr !important;
}
ul#shipping_method,
.woocommerce ul#shipping_method,
.cart_totals ul#shipping_method {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
ul#shipping_method li,
.cart_totals ul#shipping_method li {
  display: flex !important;
  align-items: flex-start;
  gap: 0.55rem;
  padding: 0 !important;
  margin: 0 !important;
  font-family: var(--ff-body);
  font-size: 0.9rem;
  color: var(--ink-2);
  line-height: 1.4;
  text-align: left;
  font-weight: 500;
}
ul#shipping_method li input[type="radio"] {
  flex-shrink: 0;
  margin: 0 !important;
  margin-top: 0.2em !important;
  accent-color: var(--red);
  width: 14px; height: 14px;
}
ul#shipping_method li label {
  margin: 0 !important;
  cursor: pointer;
  display: inline;
  font-weight: inherit;
}
ul#shipping_method li label .amount {
  font-family: var(--ff-mono);
  font-weight: 600;
  color: var(--ink);
  margin-left: 0.4rem;
}
.woocommerce-shipping-destination,
.cart_totals .woocommerce-shipping-destination {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--ink-3);
  margin: 0.85rem 0 0 !important;
  padding-top: 0.7rem;
  border-top: 1px dashed var(--edge-2);
}
.woocommerce-shipping-destination strong {
  color: var(--ink);
  font-weight: 700;
}

/* Proceed-to-checkout block sits in the surface band, not pinched */
.cart_totals .wc-proceed-to-checkout {
  margin: 0 !important;
  padding: 1.25rem 1.5rem !important;
  background: var(--paper-2);
  border-top: 1.5px solid var(--ink);
}
.cart_totals .wc-proceed-to-checkout .checkout-button {
  display: flex !important;
  width: 100%;
  padding: 1.1rem 1.5rem !important;
  font-size: 1rem !important;
  letter-spacing: 0;
}

/* Shipping calculator (the change-address form) */
.woocommerce-shipping-calculator {
  margin: 0.5rem 0 0 !important;
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  display: block;
}
.woocommerce-shipping-calculator > a.shipping-calculator-button {
  color: var(--red) !important;
  font-weight: 700;
  border-bottom: 1px dashed var(--red);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.7rem;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}
.shipping-calculator-form {
  margin-top: 1rem !important;
  display: flex; flex-direction: column; gap: 0.6rem;
  background: var(--paper);
  padding: 1rem;
  border: 1px dashed var(--edge);
}
.shipping-calculator-form .form-row { margin: 0 !important; padding: 0 !important; }
.shipping-calculator-form input,
.shipping-calculator-form select {
  width: 100% !important;
  padding: 0.65rem 0.9rem;
  border: 1px solid var(--ink);
  border-radius: 6px;
  background: var(--surface);
  font-family: var(--ff-body);
  font-size: 0.85rem;
}
.shipping-calculator-form button {
  align-self: flex-start;
}

/* CHECKOUT --------------------------------------------- */
.woocommerce-checkout {
  padding-block: 1rem 3rem;
}
.woocommerce-checkout .woocommerce-form-coupon-toggle,
.woocommerce-checkout .woocommerce-form-login-toggle {
  margin-bottom: 1rem;
}
.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: auto 1fr;
  gap: 0 2.5rem;
  align-items: start;
}
@media (max-width: 980px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }
}

.woocommerce-checkout #customer_details {
  grid-column: 1;
  grid-row: 1 / span 2;
  width: 100% !important;
  float: none !important;
}
.woocommerce-checkout #order_review_heading {
  grid-column: 2;
  grid-row: 1;
  width: 100% !important;
  float: none !important;
  margin: 0 0 1rem !important;
}
.woocommerce-checkout #order_review {
  grid-column: 2;
  grid-row: 2;
  width: 100% !important;
  float: none !important;
  position: sticky;
  top: 100px;
  align-self: start;
}
@media (max-width: 980px) {
  .woocommerce-checkout #customer_details { grid-column: 1; grid-row: 1; }
  .woocommerce-checkout #order_review_heading { grid-column: 1; grid-row: 2; }
  .woocommerce-checkout #order_review { grid-column: 1; grid-row: 3; position: static; }
}

/* "Ship to different address?" h3 + checkbox alignment */
.woocommerce-checkout #ship-to-different-address {
  margin: 1.5rem 0 1rem !important;
}
.woocommerce-checkout #ship-to-different-address label {
  display: inline-flex !important;
  align-items: center;
  gap: 0.6rem;
  cursor: pointer;
}
.woocommerce-checkout #ship-to-different-address-checkbox {
  margin: 0 !important;
  width: 18px; height: 18px;
  accent-color: var(--red);
  flex-shrink: 0;
}

/* "Create an account?" checkbox alignment */
.woocommerce-form__label-for-checkbox {
  display: flex !important;
  align-items: flex-start;
  gap: 0.6rem;
  font-family: var(--ff-body) !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--ink-2) !important;
  line-height: 1.4 !important;
  cursor: pointer;
  padding: 0.5rem 0 !important;
}
.woocommerce-form__label-for-checkbox input[type="checkbox"],
.woocommerce-form__input-checkbox {
  flex-shrink: 0;
  width: 18px; height: 18px;
  accent-color: var(--red);
  margin: 0 !important;
}

.woocommerce-checkout h3 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: -0.025em;
  margin: 0 0 1rem !important;
  color: var(--ink);
}
.woocommerce-checkout #order_review_heading {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 0 0 1rem !important;
}

/* form fields */
.woocommerce form .form-row,
.woocommerce-page form .form-row {
  margin: 0 0 1rem !important;
  padding: 0 !important;
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  display: block !important;
}
.woocommerce form .form-row.form-row-first,
.woocommerce form .form-row.form-row-last,
.woocommerce-page form .form-row.form-row-first,
.woocommerce-page form .form-row.form-row-last {
  width: calc(50% - 0.5rem) !important;
  display: inline-block !important;
}
.woocommerce form .form-row.form-row-first { margin-right: 1rem !important; }
.woocommerce form .form-row.form-row-wide,
.woocommerce-page form .form-row.form-row-wide { width: 100% !important; }
.woocommerce form .form-row label,
.woocommerce-page form .form-row label {
  display: block;
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 0.4rem;
}
.woocommerce form .form-row label .required {
  color: var(--red);
  text-decoration: none;
  border: 0;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row textarea,
.woocommerce form .form-row select,
.select2-container--default .select2-selection--single {
  width: 100% !important;
  padding: 0.85rem 1rem !important;
  background: var(--surface) !important;
  border: 1px solid var(--ink) !important;
  border-radius: 6px !important;
  font-family: var(--ff-body);
  font-size: 0.95rem;
  color: var(--ink);
  height: auto !important;
  line-height: 1.4;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  outline: 0;
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px var(--red-soft);
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 1.4 !important;
  padding: 0 !important;
  color: var(--ink);
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100% !important;
  top: 0 !important; right: 0.5rem !important;
}
.woocommerce-checkout #ship-to-different-address label {
  font-family: var(--ff-display);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--ink);
  display: flex; align-items: center; gap: 0.5rem;
}

/* order review (right column) */
.woocommerce-checkout-review-order {
  background: var(--paper-2);
  padding: 1.5rem;
  border: 1.5px solid var(--ink);
}
.woocommerce-checkout-review-order table.shop_table {
  border: 0 !important;
  background: var(--surface);
}
.woocommerce-checkout-review-order table.shop_table thead {
  background: var(--paper-2);
  color: var(--ink);
}
.woocommerce-checkout-review-order table.shop_table thead th {
  color: var(--ink-2);
}
.woocommerce-checkout-review-order .order-total .amount {
  font-family: var(--ff-display);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--red);
}

/* payment methods */
#payment, .woocommerce-checkout-payment {
  background: var(--surface) !important;
  border: 1.5px solid var(--ink);
  padding: 1rem;
  border-radius: 0 !important;
  margin-top: 1rem !important;
}
#payment ul.payment_methods,
.woocommerce-checkout-payment ul.payment_methods {
  border-bottom: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none;
}
#payment ul.payment_methods li {
  padding: 0.85rem 0 !important;
  border-bottom: 1px solid var(--edge);
}
#payment ul.payment_methods li:last-child { border-bottom: 0; }
#payment ul.payment_methods li label {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1rem;
  text-transform: none;
  color: var(--ink);
  letter-spacing: -0.01em;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
#payment ul.payment_methods li input[type="radio"] {
  accent-color: var(--red);
  width: 18px; height: 18px;
}
#payment .payment_box {
  background: var(--paper-2) !important;
  border: 0 !important;
  padding: 1rem !important;
  margin: 0.75rem 0 0 !important;
  font-family: var(--ff-body);
  font-size: 0.85rem;
  color: var(--ink-2);
  border-radius: 4px;
}
#payment .payment_box::before { display: none !important; }

#payment .place-order {
  margin-top: 1.25rem !important;
  padding: 0 !important;
}
#payment .place-order button#place_order,
button#place_order {
  display: block;
  width: 100%;
  padding: 1.2rem 1.5rem !important;
  background: var(--red) !important;
  color: white !important;
  border-radius: 999px !important;
  font-family: var(--ff-body);
  font-weight: 800 !important;
  font-size: 1.05rem !important;
  letter-spacing: -0.005em;
  border: 0 !important;
  text-transform: none !important;
  transition: background var(--t-fast), transform var(--t-fast);
}
#payment .place-order button#place_order:hover {
  background: var(--red-deep) !important;
  transform: translateY(-1px);
}

/* terms checkbox */
.woocommerce-terms-and-conditions-wrapper {
  font-size: 0.85rem;
  margin: 1rem 0 !important;
}

/* NOTICES ---------------------------------------------- */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info,
.woocommerce-notice {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem !important;
  margin-block: 0 1.5rem !important;
  border-radius: 0 !important;
  border: 0 !important;
  border-left: 3px solid !important;
  font-family: var(--ff-body);
  font-size: 0.9rem;
  line-height: 1.5;
  background: var(--surface) !important;
  color: var(--ink) !important;
}
.woocommerce-message {
  background: rgba(26,127,55,0.08) !important;
  border-color: var(--green) !important;
}
.woocommerce-message::before { display: none !important; }
.woocommerce-error {
  background: var(--red-soft) !important;
  border-color: var(--red) !important;
}
.woocommerce-error::before { display: none !important; }
.woocommerce-info {
  background: var(--paper-2) !important;
  border-color: var(--ink) !important;
}
.woocommerce-info::before { display: none !important; }

.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
  margin-left: auto;
  font-size: 0.8rem !important;
  padding: 0.45rem 0.9rem !important;
}

/* MY ACCOUNT ------------------------------------------- */
.woocommerce-account .woocommerce {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 2rem;
  padding-top: 1.5rem;
}
@media (max-width: 720px) {
  .woocommerce-account .woocommerce { grid-template-columns: 1fr; }
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0; padding: 0;
  border: 1px solid var(--edge);
  background: var(--surface);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--edge);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child { border-bottom: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 0.85rem 1rem;
  color: var(--ink);
  font-family: var(--ff-display);
  font-weight: 500;
  font-size: 0.95rem;
  transition: background var(--t-fast), color var(--t-fast);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--paper-2);
  color: var(--red);
}

/* Force .woocommerce wrapper to fill its container — WC ships flex
 * styles that shrink to content, which collapses login/register layout. */
.ew-woo > .container > .woocommerce,
.ew-woo > .container .woocommerce {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
}

/* LOGIN / REGISTER ------------------------------------- */
.woocommerce #customer_login,
.woocommerce-page #customer_login,
.woocommerce .u-columns.col2-set,
.woocommerce-page .u-columns.col2-set {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 2rem !important;
  width: 100% !important;
  max-width: 980px;
  margin: 0 auto !important;
  float: none !important;
  clear: both !important;
}
.woocommerce #customer_login::before,
.woocommerce #customer_login::after,
.woocommerce .u-columns.col2-set::before,
.woocommerce .u-columns.col2-set::after { display: none !important; content: none !important; }

.woocommerce #customer_login .u-column1,
.woocommerce #customer_login .u-column2,
.woocommerce #customer_login .col-1,
.woocommerce #customer_login .col-2,
.woocommerce-page #customer_login .col-1,
.woocommerce-page #customer_login .col-2 {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
  flex: 1 1 100% !important;
}

.woocommerce #customer_login h2,
.woocommerce-page #customer_login h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -0.025em;
  margin: 0 0 1rem !important;
  display: flex; align-items: center; gap: 0.5rem;
}
.woocommerce #customer_login h2::before {
  content: "→";
  color: var(--red);
  font-family: var(--ff-mono);
  font-weight: 700;
}
.woocommerce-form-login,
.woocommerce-form-register,
form.lost_reset_password {
  border: 1.5px solid var(--ink);
  padding: 1.75rem;
  background: var(--surface);
  margin: 0 !important;
  position: relative;
}
.woocommerce-form-register {
  background: var(--paper-2);
}
.woocommerce-form-register::before {
  content: "DAFTAR GRATIS";
  position: absolute;
  top: -1px; right: -1px;
  background: var(--red);
  color: white;
  font-family: var(--ff-mono);
  font-weight: 700;
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  padding: 4px 10px;
}
.woocommerce-form__label-for-checkbox {
  font-family: var(--ff-body) !important;
  font-size: 0.85rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--ink-2) !important;
  font-weight: 500 !important;
  display: inline-flex !important;
  align-items: center;
  gap: 0.5rem;
}
@media (max-width: 720px) {
  .u-columns.col2-set { grid-template-columns: 1fr; }
}

/* ORDER RECEIVED (THANK YOU) --------------------------- */
.woocommerce-order {
  padding-block: 1rem;
}
.woocommerce-order .woocommerce-notice--success {
  background: rgba(26,127,55,0.06) !important;
  border-left: 3px solid var(--green) !important;
  padding: 1.5rem !important;
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1.25rem;
  color: var(--ink);
}
.woocommerce-order .woocommerce-order-overview,
.woocommerce-order ul.order_details {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0;
  margin: 1.5rem 0 !important;
  padding: 0 !important;
  border: 1.5px solid var(--ink);
  border-left: 0;
}
.woocommerce-order ul.order_details li {
  padding: 1rem !important;
  border-left: 1.5px solid var(--ink);
  background: var(--surface);
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--ink-3);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 500;
}
.woocommerce-order ul.order_details li strong {
  display: block;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.1rem;
  text-transform: none;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-top: 0.25rem;
}
.woocommerce-order h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -0.025em;
  margin: 2rem 0 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--edge);
}

/* breadcrumbs ------------------------------------------ */
.woocommerce-breadcrumb {
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  color: var(--ink-3);
  margin-block: 0 1.5rem !important;
}
.woocommerce-breadcrumb a { color: var(--ink-3); }
.woocommerce-breadcrumb a:hover { color: var(--red); }

/* pagination ------------------------------------------- */
.woocommerce-pagination ul.page-numbers {
  display: flex; gap: 0.25rem;
  list-style: none;
  border: 0 !important;
  margin: 1.5rem 0 !important;
  padding: 0 !important;
}
.woocommerce-pagination ul.page-numbers li {
  margin: 0 !important;
  border: 0 !important;
}
.woocommerce-pagination .page-numbers {
  min-width: 38px; height: 38px;
  display: inline-grid !important;
  place-items: center;
  border: 1px solid var(--edge) !important;
  border-radius: 999px;
  font-family: var(--ff-mono);
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--ink-2) !important;
  background: var(--surface) !important;
  padding: 0 0.65rem !important;
  transition: all var(--t-fast);
}
.woocommerce-pagination .page-numbers:hover,
.woocommerce-pagination .page-numbers.current {
  background: var(--red) !important;
  color: white !important;
  border-color: var(--red) !important;
}

/* category archive image (when defined) ---------------- */
.woocommerce-products-header .term-thumbnail img {
  max-width: 200px;
  margin-bottom: 1rem;
}

/* "Showing the single result" wrapper ----------------- */
.woocommerce-no-products-found {
  padding: 3rem;
  text-align: center;
  font-family: var(--ff-display);
  color: var(--ink-3);
  font-size: 1.2rem;
  border: 1.5px dashed var(--edge-2);
}

/* QTY +/- buttons (custom — for cart page if WC adds) -- */
.quantity .plus, .quantity .minus {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  background: var(--paper-2);
  font-family: var(--ff-mono);
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  border: 0 !important;
  color: var(--ink);
  transition: background var(--t-fast);
}
.quantity .plus:hover, .quantity .minus:hover { background: var(--red-soft); color: var(--red); }
