/* Cart & checkout — WooCommerce Blocks (table layout) + classic fallback */

body.woocommerce-cart,
body.woocommerce-checkout {
  background: #f8fafc;
}

.tf-main .tf-container {
  width: min(1140px, 100% - 2rem);
}

.tf-main .post.type-page {
  margin: 0;
}

/* Cart layout: stack by default; side-by-side only when items column stays wide enough */
.wp-block-woocommerce-filled-cart-block {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  align-items: start;
  margin: 0 !important;
}

@media (min-width: 1060px) {
  .wp-block-woocommerce-filled-cart-block {
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 1.75rem;
  }
}

/* ── Page header ── */
.tf-cart-page__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem 1.5rem;
  padding: 2rem 0 1.25rem;
  border-bottom: 1px solid #e5e7eb;
  margin-bottom: 1.5rem;
}

.tf-cart-page__title {
  margin: 0;
  font-family: var(--tf-font-heading, "Playfair Display", Georgia, serif);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 700;
  color: var(--tf-secondary, #111);
  letter-spacing: -0.02em;
}

.tf-cart-page__continue {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--tf-primary, #111);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.tf-cart-page__continue:hover {
  opacity: 0.85;
}

/* ── Block cart shell ── */
.tf-main .wp-block-woocommerce-cart,
.tf-main .wp-block-woocommerce-checkout {
  max-width: none;
  margin: 0;
  padding: 0 0 3rem;
}

/* Left: items card */
.wp-block-woocommerce-cart-items-block {
  width: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 1.5rem 1.75rem 1.75rem !important;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: var(--tf-shadow, 0 2px 12px rgba(0, 0, 0, 0.06));
  overflow: hidden;
  box-sizing: border-box;
}

@media (min-width: 640px) {
  .wp-block-woocommerce-cart-items-block {
    padding: 1.75rem 2rem 2rem !important;
  }
}

.wp-block-woocommerce-cart-items-block .wc-block-cart__main,
.wp-block-woocommerce-cart-line-items-block {
  padding: 0;
  margin: 0;
}

/* Right: totals card */
.wp-block-woocommerce-cart-totals-block {
  width: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 1.5rem 1.75rem 1.75rem !important;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: var(--tf-shadow, 0 2px 12px rgba(0, 0, 0, 0.06));
  overflow: hidden;
  box-sizing: border-box;
}

@media (min-width: 640px) {
  .wp-block-woocommerce-cart-totals-block {
    padding: 1.75rem 2rem 2rem !important;
  }
}

@media (min-width: 769px) {
  .wp-block-woocommerce-cart-totals-block {
    position: sticky;
    top: calc(var(--tf-header-h, 72px) + 1rem);
  }
}

.wp-block-woocommerce-cart-order-summary-block,
.wp-block-woocommerce-proceed-to-checkout-block {
  padding-left: 0;
  padding-right: 0;
}

.wp-block-woocommerce-cart-order-summary-block {
  padding-top: 0;
}

.wp-block-woocommerce-proceed-to-checkout-block {
  padding-bottom: 0;
  margin-top: 0.25rem;
}

/* ── Cart items: CSS grid rows (Product | Details | Total) ── */
table.wc-block-cart-items {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  --tf-cart-gap: 1.5rem;
  --tf-cart-col-image: 96px;
  --tf-cart-col-total: 96px;
}

.wc-block-cart__main table.wc-block-cart-items th,
.wc-block-cart__main table.wc-block-cart-items td,
table.wc-block-cart-items .wc-block-cart-items__header th,
table.wc-block-cart-items .wc-block-cart-items__row td {
  box-sizing: border-box;
  margin: 0;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Desktop / tablet: each row is the same 3-column grid */
@media (min-width: 768px) {
  table.wc-block-cart-items {
    display: block;
  }

  table.wc-block-cart-items thead,
  table.wc-block-cart-items tbody {
    display: block;
  }

  table.wc-block-cart-items .wc-block-cart-items__header,
  table.wc-block-cart-items .wc-block-cart-items__row {
    display: grid !important;
    grid-template-columns: var(--tf-cart-col-image) minmax(0, 1fr) var(--tf-cart-col-total);
    column-gap: var(--tf-cart-gap);
    align-items: start;
    width: 100%;
  }

  table.wc-block-cart-items .wc-block-cart-items__header {
    padding-bottom: 1rem;
    border-bottom: 1px solid #e5e7eb;
  }

  table.wc-block-cart-items .wc-block-cart-items__row {
    padding: 1.5rem 0;
    border-bottom: 1px solid #f3f4f6;
  }

  table.wc-block-cart-items .wc-block-cart-items__row:last-child {
    border-bottom: none;
  }

  table.wc-block-cart-items .wc-block-cart-items__header th,
  table.wc-block-cart-items .wc-block-cart-items__row td {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  .wc-block-cart-items__header-image,
  .wc-block-cart-item__image {
    grid-column: 1;
  }

  .wc-block-cart-items__header-product,
  .wc-block-cart-item__product {
    grid-column: 2;
    min-width: 0;
  }

  .wc-block-cart-items__header-total,
  .wc-block-cart-item__total {
    grid-column: 3;
    text-align: right !important;
    justify-self: end;
  }
}

/* Header cells */
.wc-block-cart__main table.wc-block-cart-items .wc-block-cart-items__header th,
table.wc-block-cart-items .wc-block-cart-items__header th {
  padding-top: 0.75rem !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #9ca3af;
  white-space: nowrap;
  text-align: left;
}

.wc-block-cart-items__header .wc-block-cart-items__header-total {
  text-align: right !important;
}

.wc-block-cart-items__header .wc-block-cart-items__header-product {
  visibility: visible !important;
}

.wc-block-cart-items__header .wc-block-cart-items__header-image span {
  display: block;
}

/* Body cells */
.wc-block-cart__main table.wc-block-cart-items .wc-block-cart-items__row td,
table.wc-block-cart-items .wc-block-cart-items__row td {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  border: none !important;
}

.wc-block-cart-items__row:last-child td {
  border-bottom: none !important;
}

.wc-block-cart-item__image img {
  width: var(--tf-cart-col-image);
  height: var(--tf-cart-col-image);
  max-width: 100%;
  object-fit: cover;
  border-radius: 8px;
  background: #f3f4f6;
  border: 1px solid #eef2f7;
  display: block;
}

.wc-block-cart-item__product {
  min-width: 0;
}

.wc-block-cart-item__wrap {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.wc-block-cart-item__total {
  font-weight: 700;
  font-size: 1rem;
  color: var(--tf-secondary, #111);
  white-space: nowrap;
}

@media (max-width: 767px) {
  table.wc-block-cart-items {
    --tf-cart-col-image: 72px;
    --tf-cart-gap: 1rem;
    --tf-cart-col-total: 76px;
  }
}

/* Product name — 2-line clamp */
.wc-block-cart .wc-block-components-product-name,
.wc-block-cart .wc-block-components-product-name a {
  display: -webkit-box !important;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  line-height: 1.4;
  max-height: 2.8em;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--tf-secondary, #111) !important;
  text-decoration: none;
}

.wc-block-cart .wc-block-components-product-name a:hover {
  color: var(--tf-primary) !important;
}

.wc-block-components-product-price {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
}

.wc-block-components-product-metadata {
  font-size: 0.8rem;
  color: #6b7280;
  margin-top: 0.15rem;
}

.wc-block-components-product-metadata__description p {
  margin: 0;
  display: inline-block;
  padding: 0.2rem 0.55rem;
  background: #f3f4f6;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #4b5563;
}

/* Quantity row */
.wc-block-cart-item__quantity {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  margin-top: 1rem;
  padding-top: 0.85rem;
  border-top: 1px solid #f3f4f6;
}

.wc-block-cart-item__quantity::before {
  content: "Qty";
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9ca3af;
}

.wc-block-components-quantity-selector {
  border: 1px solid #d1d5db;
  border-radius: 8px;
  overflow: hidden;
  display: inline-flex;
  align-items: stretch;
  background: #fff;
}

.wc-block-components-quantity-selector__input {
  min-width: 2.75rem;
  max-width: 3rem;
  text-align: center;
  border: none !important;
  font-weight: 700;
  font-size: 0.9rem;
  padding: 0.45rem 0 !important;
}

.wc-block-components-quantity-selector__button {
  min-width: 2.25rem;
  border: none !important;
  background: #f9fafb !important;
  color: #374151 !important;
  font-size: 1.1rem;
  line-height: 1;
}

.wc-block-components-quantity-selector__button:hover {
  background: #f3f4f6 !important;
  color: #111 !important;
}

.wc-block-cart-item__remove-link,
.wc-block-components-product-details__remove-button {
  font-size: 0.78rem !important;
  font-weight: 600;
  color: #9ca3af !important;
  text-decoration: none !important;
  padding: 0.35rem 0;
}

.wc-block-cart-item__remove-link:hover,
.wc-block-components-product-details__remove-button:hover {
  color: #ef4444 !important;
}

/* ── Totals sidebar ── */
.wc-block-cart__totals-title,
.wc-block-components-totals-item__label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #9ca3af;
}

.wc-block-components-totals-wrapper {
  border-top: 1px solid #e5e7eb;
  margin-top: 1rem;
  padding-top: 1rem;
}

.wc-block-components-totals-item {
  padding: 0.5rem 0;
}

.wc-block-components-totals-footer-item {
  margin-top: 0.75rem;
  padding-top: 1rem;
  border-top: 1px solid #e5e7eb;
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--tf-secondary, #111);
}

.wc-block-components-totals-coupon-link {
  font-size: 0.85rem;
  font-weight: 600;
  color: #6b7280;
}

.wc-block-cart__submit-container {
  margin-top: 1.25rem;
}

.wc-block-cart__submit-button .wc-block-components-button,
.wc-block-components-checkout-button,
.wc-block-cart .wc-block-components-button.contained,
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-components-button {
  width: 100% !important;
  background: var(--tf-secondary, #111) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 1rem 1.25rem !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  transition: background 0.15s ease, transform 0.15s ease;
}

.wc-block-cart__submit-button .wc-block-components-button:hover,
.wc-block-components-checkout-button:hover,
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-components-button:hover {
  background: var(--tf-primary, #374151) !important;
}

/* ── Empty cart ── */
.wp-block-woocommerce-empty-cart-block {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 2.5rem 1.5rem;
  box-shadow: var(--tf-shadow);
  text-align: center;
}

.wc-block-cart__empty-cart__title {
  font-family: var(--tf-font-heading, "Playfair Display", Georgia, serif);
  font-size: 1.5rem;
  color: var(--tf-secondary, #111);
  margin-bottom: 0.5rem;
}

.wc-block-grid.wp-block-product-new {
  margin-top: 2rem;
  text-align: left;
}

/* Shared 2-line title clamp (empty cart product grid) */
.tf-title-clamp-2,
.wc-block-grid__product-title,
.wc-block-grid__product-title a,
.woocommerce-cart .product-name a,
.woocommerce-checkout-review-order-table .product-name a {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  line-height: 1.35;
  max-height: 2.7em;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--tf-secondary, #111);
}

.wc-block-grid__product-title {
  min-height: 2.7em;
  margin: 0 0 0.35rem;
}

.wc-block-grid__product-title a {
  color: inherit;
  text-decoration: none;
}

.wc-block-grid__product-title a:hover {
  color: var(--tf-primary);
}

.wc-block-grid__product {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #eef2f7;
  border-radius: 10px;
  overflow: hidden;
  padding-bottom: 0.75rem;
}

.wc-block-grid__product-link {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.wc-block-grid__product-add-to-cart {
  margin-top: auto;
  padding: 0 0.75rem;
}

/* ── Classic cart fallback ── */
.woocommerce-cart-form {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: var(--tf-shadow);
}

.woocommerce-cart-form .product-name a {
  font-weight: 600;
}

.woocommerce-cart .cart_totals {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: var(--tf-shadow);
}

.woocommerce-cart .checkout-button {
  width: 100%;
  text-align: center;
  background: var(--tf-secondary, #111) !important;
  color: #fff !important;
  border-radius: 8px !important;
}

/* ── Mobile cart & checkout ── */
@media (max-width: 767px) {
  body.woocommerce-cart,
  body.woocommerce-checkout {
    padding-bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
  }

  .tf-main .tf-container {
    width: min(1080px, 100% - 1.25rem);
  }

  .tf-cart-page__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 1.25rem 0 1rem;
    margin-bottom: 1rem;
  }

  .tf-cart-page__title {
    font-size: 1.35rem;
  }

  .tf-main .wp-block-woocommerce-cart,
  .tf-main .wp-block-woocommerce-checkout {
    padding-bottom: 2rem;
  }

  .wp-block-woocommerce-filled-cart-block {
    gap: 0.85rem;
  }

  .wp-block-woocommerce-cart-items-block,
  .wp-block-woocommerce-cart-totals-block {
    padding: 1rem 1.125rem 1.125rem !important;
    border-radius: 10px;
  }

  /* WC mobile: table rows become grid, header hidden */
  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__header {
    display: none !important;
  }

  table.wc-block-cart-items {
    table-layout: auto;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row {
    display: grid !important;
    grid-template-columns: 72px minmax(0, 1fr) auto !important;
    grid-template-rows: auto auto;
    gap: 0.65rem 0.75rem;
    padding: 1rem 0 !important;
    border-bottom: 1px solid #f3f4f6;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row:last-child {
    border-bottom: none;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row td {
    display: block;
    padding: 0 !important;
    border: none !important;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__image {
    grid-column: 1;
    grid-row: 1;
    width: 76px !important;
    min-width: 76px !important;
    max-width: 76px !important;
    padding-right: 1rem !important;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__image img {
    width: 72px;
    height: 72px;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__product {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    padding-left: 0.25rem !important;
    padding-right: 0.5rem !important;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__total {
    grid-column: 3;
    grid-row: 1;
    width: auto !important;
    max-width: none !important;
    align-self: start;
    font-size: 0.95rem;
  }

  .wc-block-cart table.wc-block-cart-items .wc-block-cart-items__row .wc-block-cart-item__quantity {
    grid-column: 1 / -1;
    grid-row: 2;
    margin-top: 0;
    padding-top: 0.65rem;
    border-top: 1px solid #f3f4f6;
    justify-content: flex-start;
  }

  .wc-block-cart .wc-block-components-product-name,
  .wc-block-cart .wc-block-components-product-name a {
    font-size: 0.85rem;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    max-height: 4.2em;
  }

  .wc-block-components-quantity-selector__button {
    min-width: 2.5rem;
    min-height: 2.5rem;
  }

  .wc-block-cart__submit-button .wc-block-components-button,
  .wp-block-woocommerce-proceed-to-checkout-block .wc-block-components-button {
    min-height: 3rem;
    padding: 0.95rem 1rem !important;
  }

  /* Empty cart recommendations */
  .wc-block-grid.has-4-columns .wc-block-grid__products {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.75rem;
  }

  .wc-block-grid__product-title {
    min-height: 0;
    font-size: 0.82rem;
  }

  .wp-block-woocommerce-empty-cart-block {
    padding: 1.75rem 1rem;
  }
}

/* Checkout mobile */
@media (max-width: 767px) {
  .wc-block-checkout .wc-block-components-sidebar-layout {
    flex-direction: column;
  }

  .wc-block-checkout .wc-block-components-main,
  .wc-block-checkout .wc-block-components-sidebar {
    width: 100% !important;
    padding: 0 !important;
  }

  .wc-block-checkout .wc-block-components-checkout-place-order-button {
    min-height: 3rem;
  }
}
