/* ─────────────────────────────────────────────────────────────────────────────
   Solutech — WordPress-only shop chrome: cart button, mini-cart drawer,
   and cart/checkout styling (mapped onto the shared design tokens).
   ───────────────────────────────────────────────────────────────────────────── */

/* ── Header cart button + count badge ──────────────────────────────────────── */
.cart-btn {
  position: relative; display: inline-grid; place-items: center;
  width: 44px; height: 44px; border-radius: 12px; margin-left: .35rem;
  border: 1px solid var(--line); background: var(--card); color: var(--ink);
  cursor: pointer; transition: border-color .25s var(--ease), transform .25s var(--ease);
}
.cart-btn:hover { border-color: var(--ink); transform: translateY(-1px); }
.cart-btn__count {
  position: absolute; top: -6px; right: -6px; min-width: 19px; height: 19px; padding: 0 5px;
  border-radius: 999px; background: var(--accent); color: #fff;
  font-family: var(--font-mono); font-size: .68rem; font-weight: 700;
  display: grid; place-items: center; line-height: 1;
}
.cart-btn__count.is-empty { display: none; }
body.cart-adding .cart-btn { opacity: .7; }

/* ── Mini-cart drawer ──────────────────────────────────────────────────────── */
.mini-cart { position: fixed; inset: 0; z-index: 200; visibility: hidden; pointer-events: none; }
.mini-cart.is-open { visibility: visible; pointer-events: auto; }
.mini-cart__overlay { position: absolute; inset: 0; background: rgba(23,20,31,.5); opacity: 0; transition: opacity .35s var(--ease); }
.mini-cart.is-open .mini-cart__overlay { opacity: 1; }
.mini-cart__panel {
  position: absolute; top: 0; right: 0; height: 100%; width: min(430px, 92vw);
  background: var(--surface); box-shadow: var(--shadow-lg); display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .42s var(--ease);
}
.mini-cart.is-open .mini-cart__panel { transform: none; }
.mini-cart__head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-5); border-bottom: 1px solid var(--line); }
.mini-cart__head h3 { font-size: var(--fs-4); }
.mini-cart__close { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; border: 1px solid var(--line); background: var(--card); color: var(--ink); cursor: pointer; }
.mini-cart__close:hover { border-color: var(--ink); }
.mini-cart__body { flex: 1; overflow-y: auto; padding: var(--space-5); }
body.cart-open { overflow: hidden; }
@media (prefers-reduced-motion: reduce) { .mini-cart__panel, .mini-cart__overlay { transition: none; } }

/* WooCommerce mini-cart internals */
.mini-cart__body .woocommerce-mini-cart { list-style: none; margin: 0; padding: 0; }
.mini-cart__body li.woocommerce-mini-cart-item { position: relative; display: flex; align-items: center; gap: .85rem; padding: var(--space-4) 0; border-bottom: 1px solid var(--line); font-size: var(--fs-sm); }
.mini-cart__body li.woocommerce-mini-cart-item a:not(.remove) { color: var(--ink); font-weight: 600; }
.mini-cart__body li.woocommerce-mini-cart-item img { order: -1; width: 58px; height: auto; border-radius: 8px; border: 1px solid var(--line); }
.mini-cart__body .quantity { display: block; color: var(--fg-muted); font-family: var(--font-mono); font-size: var(--fs-xs); margin-top: .2rem; }
.mini-cart__body a.remove { position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 22px; height: 22px; line-height: 20px; text-align: center; border-radius: 50%; color: var(--muted) !important; background: var(--sand); font-size: 1rem; text-decoration: none; }
.mini-cart__body a.remove:hover { background: var(--coral); color: #fff !important; }
.mini-cart__body .woocommerce-mini-cart__total { display: flex; justify-content: space-between; align-items: baseline; padding: var(--space-4) 0; font-family: var(--font-mono); font-weight: 700; font-size: var(--fs-4); border-bottom: 0; }
.mini-cart__body .woocommerce-mini-cart__buttons { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-2) 0 0; margin: 0; }
.mini-cart__body .woocommerce-mini-cart__empty-message { color: var(--fg-muted); text-align: center; padding: var(--space-7) 0; }

/* ── WooCommerce buttons → our .btn look (classic + blocks) ─────────────────── */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce a.button.alt, .woocommerce button.button.alt,
.woo-page .button, .mini-cart__body .button, #place_order, .checkout-button,
.wc-block-components-button {
  display: inline-flex; align-items: center; justify-content: center; gap: .5ch;
  font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); line-height: 1.2;
  padding: .9rem 1.6rem; border-radius: var(--radius-pill); border: 1.5px solid transparent;
  background: var(--accent); color: #fff !important; cursor: pointer; text-decoration: none;
  transition: transform .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);
  box-shadow: var(--shadow-sm);
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woo-page .button:hover, .mini-cart__body .button:hover,
#place_order:hover, .checkout-button:hover, .wc-block-components-button:hover {
  background: var(--accent-ink); transform: translateY(-2px); box-shadow: var(--shadow);
}
/* secondary (e.g. "View cart", "Update cart") = ghost */
.mini-cart__body .woocommerce-mini-cart__buttons a:not(.checkout),
.woo-page .button[name="update_cart"], .woocommerce a.button.wc-backward {
  background: var(--card); color: var(--ink) !important; border-color: var(--line); box-shadow: none;
}
.mini-cart__body .woocommerce-mini-cart__buttons a:not(.checkout):hover,
.woocommerce a.button.wc-backward:hover { border-color: var(--ink); background: var(--card); }

/* ── Cart & checkout page (wide) ───────────────────────────────────────────── */
.woo-page { max-width: var(--maxw); }
.woo-page table.shop_table {
  width: 100%; border-collapse: collapse; background: var(--card);
  border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden;
}
.woo-page table.shop_table th {
  font-family: var(--font-mono); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .08em;
  color: var(--fg-muted); text-align: left; padding: 1rem 1.1rem; border-bottom: 1px solid var(--line); background: var(--sand);
}
.woo-page table.shop_table td { padding: 1rem 1.1rem; border-top: 1px solid var(--line); vertical-align: middle; }
.woo-page .product-thumbnail img, .woo-page .cart_item img { width: 64px; height: auto; border-radius: 8px; border: 1px solid var(--line); }
.woo-page .product-name a { color: var(--ink); font-weight: 600; }
.woo-page input.qty { padding: .55rem; border: 1.5px solid var(--line); border-radius: 8px; width: 64px; text-align: center; font: inherit; }
.woo-page .cart-collaterals { margin-top: var(--space-6); display: grid; grid-template-columns: 1fr minmax(320px, 400px); gap: var(--space-6); align-items: start; }
.woo-page .cart_totals, .woo-page .cross-sells { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--space-6); }
.woo-page .cart_totals h2 { font-size: var(--fs-3); margin-bottom: var(--space-3); }
.woo-page .wc-proceed-to-checkout { padding-top: var(--space-4); }
.woo-page .wc-proceed-to-checkout .checkout-button { width: 100%; font-size: var(--fs-body); padding: 1.05rem 2rem; }
@media (max-width: 860px) { .woo-page .cart-collaterals { grid-template-columns: 1fr; } }

/* checkout (classic) */
.woo-page .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
.woocommerce form .form-row { margin-bottom: var(--space-4); }
.woocommerce form .form-row label { font-weight: 600; font-size: var(--fs-sm); display: block; margin-bottom: .35rem; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea,
.woocommerce form .form-row select, .woocommerce .select2-container .select2-selection {
  width: 100%; padding: .8rem .9rem; border: 1.5px solid var(--line); border-radius: var(--radius-sm);
  font: inherit; font-size: var(--fs-sm); background: var(--card); color: var(--fg);
}
.woocommerce-checkout #order_review, .woocommerce-checkout #order_review_heading {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--space-5) var(--space-6);
}
.woocommerce-checkout #order_review_heading { border-bottom: 0; border-radius: var(--radius-lg) var(--radius-lg) 0 0; margin-bottom: 0; }
.woocommerce-checkout #order_review { border-radius: 0 0 var(--radius-lg) var(--radius-lg); border-top: 0; }
.woocommerce-checkout #order_review table.shop_table { border: 0; border-radius: 0; }
#place_order { width: 100%; font-size: var(--fs-body); padding: 1.1rem 2rem; margin-top: var(--space-4); }
@media (max-width: 820px) { .woo-page .col2-set { grid-template-columns: 1fr; } }

/* Block cart/checkout are already full-width; just give them room */
.woo-page .wp-block-woocommerce-cart, .woo-page .wp-block-woocommerce-checkout { max-width: 100%; }
