/* =====================================================
   WooCommerce Cart Block — site-style overrides
   Layout: image | name (+ unit price) | qty | remove | total — single line
   Hides product description; styles the checkout button.
   Uses :where() at top to keep specificity low, then !important
   selectively where WC ships container-query rules we must beat.
   ===================================================== */

/* Force one-line row layout regardless of WC's container queries.
   We turn .wc-block-cart-item__product / __wrap into display:contents so
   their grandchildren participate in the row's grid directly. */
.wp-block-woocommerce-cart .wc-block-cart-items__row {
  display: grid !important;
  grid-template-columns: 80px minmax(0, 1fr) auto auto !important;
  align-items: center;
  gap: 16px;
  padding: 18px 0 !important;
  border-top: 1px solid var(--line-soft);
  position: relative;
  transition: opacity .2s ease;
}
.wp-block-woocommerce-cart .wc-block-cart-items__row > .wc-block-cart-item__product,
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__wrap {
  display: contents !important;
}
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__image {
  grid-column: 1;
  grid-row: 1 / span 2;
  padding: 0 !important;
}
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__image img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  background: var(--paper);
}
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-components-product-name {
  grid-column: 2;
  grid-row: 1;
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
  align-self: end;
}
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__prices {
  grid-column: 2;
  grid-row: 2;
  font-family: var(--font-mono);
  font-size: 12px;
  color: rgba(14, 14, 14, 0.6);
  align-self: start;
}

/* Hide description / metadata / sale badge clutter */
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-components-product-metadata,
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-components-product-details,
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__short-description,
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-components-sale-badge {
  display: none !important;
}

/* Quantity selector + remove link — combined cell at end of row, before total */
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__quantity {
  grid-column: 3;
  grid-row: 1 / span 2;
  align-self: center;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.wp-block-woocommerce-cart .wc-block-cart-item__quantity .wc-block-components-quantity-selector {
  border: 1px solid var(--ink);
  border-radius: 6px;
  background: var(--paper);
  overflow: hidden;
  display: inline-flex;
  align-items: center;
}
.wp-block-woocommerce-cart .wc-block-cart-item__quantity .wc-block-components-quantity-selector__button {
  width: 30px;
  height: 30px;
  background: var(--paper);
  color: var(--ink);
  border: 0;
  font-size: 16px;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.wp-block-woocommerce-cart .wc-block-cart-item__quantity .wc-block-components-quantity-selector__button:hover:not(:disabled) {
  background: var(--orange);
  color: var(--paper);
}
.wp-block-woocommerce-cart .wc-block-cart-item__quantity .wc-block-components-quantity-selector__input {
  width: 36px;
  text-align: center;
  border: 0;
  background: transparent;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 13px;
  padding: 0;
}
.wp-block-woocommerce-cart .wc-block-cart-item__quantity .wc-block-cart-item__remove-link {
  display: inline-flex !important;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(14, 14, 14, 0.55);
  text-decoration: none !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  width: auto !important;
  height: auto !important;
  cursor: pointer;
  transition: color .15s ease;
}
.wp-block-woocommerce-cart .wc-block-cart-item__quantity .wc-block-cart-item__remove-link:hover {
  color: var(--orange) !important;
}

/* Total — right-aligned end of row */
.wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__total {
  grid-column: 4;
  grid-row: 1 / span 2;
  text-align: right;
  align-self: center;
  padding: 0 !important;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
  white-space: nowrap;
}

/* Hide table header (image / product / total) — visual rhythm comes from rows */
.wp-block-woocommerce-cart .wc-block-cart-items__header {
  display: none !important;
}

/* Loading state during AJAX qty/remove — block row, dim, animate.
   WC sets .is-disabled on the row while a mutation is in flight. */
.wp-block-woocommerce-cart .wc-block-cart-items__row.is-disabled {
  opacity: 1 !important;
  pointer-events: none !important;
}
.wp-block-woocommerce-cart .wc-block-cart-items__row.is-disabled::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.55);
  z-index: 2;
  border-radius: 4px;
  animation: roofer-cart-row-pulse 1s ease-in-out infinite;
  pointer-events: none;
}
@keyframes roofer-cart-row-pulse {
  0%, 100% { background: rgba(255, 255, 255, 0.4); }
  50%      { background: rgba(255, 255, 255, 0.75); }
}

/* Whole cart-items block dim during global update (e.g. cart totals refresh) */
.wp-block-woocommerce-cart .wc-block-cart-items.is-loading {
  position: relative;
  pointer-events: none;
}
.wp-block-woocommerce-cart .wc-block-cart-items.is-loading::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.4);
  z-index: 2;
  animation: roofer-cart-row-pulse 1s ease-in-out infinite;
  pointer-events: none;
}

/* =====================================================
   Checkout submit button — site-style primary
   ===================================================== */
.wp-block-woocommerce-cart .wc-block-cart__submit-button.wc-block-components-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  padding: 18px 28px;
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  background: var(--orange) !important;
  color: var(--paper) !important;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .15s ease;
  box-shadow: 4px 4px 0 var(--ink);
  min-height: auto;
  height: auto;
}
.wp-block-woocommerce-cart .wc-block-cart__submit-button.wc-block-components-button:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--ink);
}
.wp-block-woocommerce-cart .wc-block-cart__submit-button.wc-block-components-button[aria-disabled="true"] {
  opacity: .55;
  cursor: not-allowed;
}

/* "Перейти в магазин" / continue-shopping ghost button (if present) */
.wp-block-woocommerce-cart .wp-block-woocommerce-empty-cart-block .wp-block-button__link {
  background: var(--ink) !important;
  color: var(--paper) !important;
  border: 2px solid var(--ink) !important;
  border-radius: var(--radius) !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

/* Mobile: stack qty/total under product info */
@media (max-width: 640px) {
  .wp-block-woocommerce-cart .wc-block-cart-items__row {
    grid-template-columns: 64px minmax(0, 1fr) auto !important;
    gap: 12px;
  }
  .wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__image img {
    width: 64px;
    height: 64px;
  }
  .wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__quantity {
    grid-column: 2;
    grid-row: 3;
    flex-direction: row;
    justify-content: flex-start;
    margin-top: 6px;
    align-self: start;
  }
  .wp-block-woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__total {
    grid-column: 3;
    grid-row: 1 / span 3;
  }
}
