/* ==============================================
   KharidarBazaar — WooCommerce CSS
   ============================================== */

/* Global WooCommerce overrides */
.woocommerce,
.woocommerce-page { font-family: var(--kb-font); color: var(--kb-charcoal); }

/* Remove default WooCommerce styles we override */
.woocommerce #content div.product,
.woocommerce div.product { max-width: none; }

/* Notices */
.woocommerce-notices-wrapper { padding: 0 0 16px; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-radius: var(--kb-radius-sm); border-left: 4px solid var(--kb-green);
  padding: 14px 16px; background: var(--kb-green-light);
  color: var(--kb-charcoal); margin-bottom: 16px; font-size: 0.9rem;
  list-style: none;
}
.woocommerce-error { border-left-color: #ef4444; background: #fef2f2; }
.woocommerce-info { border-left-color: #3b82f6; background: #eff6ff; }

/* Buttons */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 24px; border-radius: var(--kb-radius-sm);
  background: var(--kb-green); color: #fff; font-weight: 600; font-size: 0.9rem;
  border: none; cursor: pointer; transition: var(--kb-transition);
  text-decoration: none; line-height: 1;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
  background: var(--kb-green-dark); color: #fff; transform: translateY(-1px);
}
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt { background: var(--kb-green); }
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover { background: var(--kb-green-dark); }

/* Forms */
.woocommerce form .form-row { margin-bottom: 16px; }
.woocommerce form .form-row label {
  font-size: 0.88rem; font-weight: 600; color: var(--kb-charcoal); margin-bottom: 6px; display: block;
}
.woocommerce form .form-row input,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  width: 100%; padding: 11px 14px; border: 1px solid var(--kb-border);
  border-radius: var(--kb-radius-sm); font-size: 0.9rem; transition: var(--kb-transition);
  outline: none;
}
.woocommerce form .form-row input:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--kb-green); box-shadow: 0 0 0 3px rgba(26,122,74,0.1);
}

/* Product Archive */
.woocommerce ul.products { margin: 0; padding: 0; list-style: none; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.woocommerce ul.products li.product {
  background: #fff; border: 1px solid var(--kb-border); border-radius: var(--kb-radius);
  overflow: hidden; box-shadow: var(--kb-shadow); transition: var(--kb-transition);
  display: flex; flex-direction: column;
}
.woocommerce ul.products li.product:hover { box-shadow: var(--kb-shadow-hover); transform: translateY(-3px); }
.woocommerce ul.products li.product a img { width: 100%; aspect-ratio: 1; object-fit: cover; transition: transform 0.4s; }
.woocommerce ul.products li.product:hover a img { transform: scale(1.04); }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 0.95rem; font-weight: 700; padding: 16px 16px 8px; color: var(--kb-charcoal);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.woocommerce ul.products li.product .price {
  padding: 0 16px 8px; font-size: 1rem; font-weight: 800; color: var(--kb-green);
}
.woocommerce ul.products li.product .price del { font-size: 0.82rem; color: var(--kb-muted); font-weight: 400; margin-right: 6px; }
.woocommerce ul.products li.product .button { margin: auto 16px 16px; }

/* Sale badge */
.woocommerce span.onsale {
  background: #ef4444; color: #fff; border-radius: 4px;
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
  padding: 3px 8px; top: 10px; left: 10px;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination ul {
  display: flex; gap: 6px; justify-content: center; margin-top: 40px; flex-wrap: wrap;
}
.woocommerce nav.woocommerce-pagination ul li { display: flex; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  min-width: 40px; height: 40px; border-radius: var(--kb-radius-sm);
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--kb-border); font-size: 0.88rem; font-weight: 600;
  color: var(--kb-charcoal); transition: var(--kb-transition); padding: 0 12px;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--kb-green); color: #fff; border-color: var(--kb-green);
}

/* Single Product */
.woocommerce div.product .woocommerce-product-gallery__wrapper { border-radius: var(--kb-radius-lg); overflow: hidden; }
.woocommerce div.product p.price, .woocommerce div.product span.price {
  font-size: 1.6rem; font-weight: 800; color: var(--kb-green);
}
.woocommerce div.product .woocommerce-product-rating .star-rating { color: var(--kb-kraft); }
.woocommerce div.product form.cart { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.woocommerce div.product form.cart .qty {
  width: 80px; padding: 11px 14px; border: 1px solid var(--kb-border);
  border-radius: var(--kb-radius-sm); font-size: 0.95rem; text-align: center; outline: none;
}
.woocommerce div.product form.cart .qty:focus { border-color: var(--kb-green); }

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex; border-bottom: 2px solid var(--kb-border); padding: 0; margin: 0;
  list-style: none; overflow-x: auto;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  margin: 0; padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block; padding: 12px 20px; font-size: 0.9rem; font-weight: 600;
  color: var(--kb-muted); border-bottom: 2px solid transparent; margin-bottom: -2px;
  transition: var(--kb-transition);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover { color: var(--kb-green); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--kb-green); border-bottom-color: var(--kb-green); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active, .woocommerce div.product .woocommerce-tabs ul.tabs li { background: transparent; border: none; }
.woocommerce div.product .woocommerce-tabs .panel { padding: 24px 0; border: none; }

/* Related products */
.related.products > h2, .upsells.products > h2 { font-size: 1.3rem; font-weight: 800; margin-bottom: 24px; }

/* Cart */
.woocommerce table.cart { width: 100%; border-collapse: collapse; }
.woocommerce table.cart thead th { padding: 12px 16px; text-align: left; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--kb-muted); border-bottom: 2px solid var(--kb-border); }
.woocommerce table.cart tbody td { padding: 16px; border-bottom: 1px solid var(--kb-border); vertical-align: middle; }
.woocommerce table.cart .product-thumbnail img { width: 64px; height: 64px; border-radius: 8px; object-fit: cover; }
.woocommerce table.cart .product-name a { font-weight: 600; color: var(--kb-charcoal); }
.woocommerce table.cart .product-price, .woocommerce table.cart .product-subtotal { font-weight: 700; color: var(--kb-green); }
.woocommerce .cart-collaterals { margin-top: 32px; }
.woocommerce .cart_totals { background: var(--kb-bg-alt); border-radius: var(--kb-radius); padding: 28px; border: 1px solid var(--kb-border); }
.woocommerce .cart_totals h2 { font-size: 1.1rem; margin-bottom: 16px; }
.woocommerce .cart_totals table { width: 100%; border-collapse: collapse; }
.woocommerce .cart_totals table th, .woocommerce .cart_totals table td { padding: 10px 0; border-bottom: 1px solid var(--kb-border); font-size: 0.9rem; }
.woocommerce .cart_totals table .order-total th, .woocommerce .cart_totals table .order-total td { font-size: 1.1rem; font-weight: 800; color: var(--kb-green); border-bottom: none; padding-top: 16px; }
.woocommerce .coupon { display: flex; gap: 10px; margin-bottom: 16px; }
.woocommerce .coupon input { flex: 1; padding: 11px 14px; border: 1px solid var(--kb-border); border-radius: var(--kb-radius-sm); outline: none; }
.woocommerce .coupon input:focus { border-color: var(--kb-green); }

/* Checkout */
.woocommerce-checkout #order_review_heading { font-size: 1.1rem; font-weight: 800; margin-bottom: 16px; }
.woocommerce-checkout .woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; }
.woocommerce-checkout .woocommerce-checkout-review-order-table th { padding: 10px 16px; text-align: left; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--kb-muted); border-bottom: 2px solid var(--kb-border); }
.woocommerce-checkout .woocommerce-checkout-review-order-table td { padding: 12px 16px; border-bottom: 1px solid var(--kb-border); font-size: 0.9rem; }
.woocommerce-checkout #payment { background: var(--kb-bg-alt); border-radius: var(--kb-radius); padding: 24px; border: 1px solid var(--kb-border); }
.woocommerce-checkout #payment ul.payment_methods { list-style: none; margin-bottom: 20px; }
.woocommerce-checkout #payment ul.payment_methods li { padding: 12px; border-bottom: 1px solid var(--kb-border); }
.woocommerce-checkout #payment .place-order { padding-top: 20px; }
.woocommerce-checkout #payment #place_order {
  width: 100%; padding: 16px; font-size: 1rem;
  border-radius: var(--kb-radius-sm);
}

/* Order tracking */
.woocommerce .track_order { background: var(--kb-bg-alt); border-radius: var(--kb-radius); padding: 28px; border: 1px solid var(--kb-border); }

/* Stars */
.star-rating { color: var(--kb-kraft); font-size: 1rem; }
.woocommerce .star-rating::before { color: #e5e7eb; }
.woocommerce .star-rating span::before { color: var(--kb-kraft); }

/* Review form */
.woocommerce #reviews #comments ol.commentlist .comment_container { display: flex; gap: 16px; }
.woocommerce #reviews #comments ol.commentlist li img.avatar { border-radius: 50%; width: 48px; height: 48px; border: 2px solid var(--kb-border); }
.woocommerce #reviews #respond input#submit { margin-top: 16px; }

/* Mobile WooCommerce */
@media (max-width: 768px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .woocommerce table.cart { display: block; overflow-x: auto; }
  .woocommerce div.product form.cart { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
  .woocommerce ul.products { grid-template-columns: 1fr; }
}

/* v1.2.1 — Product archive/category layout fix
   Removes the shop sidebar from the rendered WooCommerce template and forces
   WooCommerce archive cards to behave as proper CSS-grid items instead of using
   the default WooCommerce float/width rules. */
.kb-shop-container {
  padding-top: 40px;
  padding-bottom: 64px;
}
.kb-wc-content-full {
  width: 100%;
  max-width: 100%;
}
.woocommerce .woocommerce-result-count {
  margin: 0 0 22px;
  color: var(--kb-charcoal);
  font-size: 0.95rem;
}
.woocommerce .woocommerce-ordering {
  margin: 0 0 22px;
}
.woocommerce .woocommerce-ordering select {
  min-width: 220px;
  padding: 10px 14px;
  border: 1px solid var(--kb-border);
  border-radius: var(--kb-radius-sm);
  background: #fff;
  color: var(--kb-charcoal);
  font-size: 0.9rem;
}
.woocommerce ul.products,
.woocommerce-page ul.products {
  clear: both;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
  width: 100%;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
  content: none !important;
  display: none !important;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.woocommerce ul.products.columns-1 li.product,
.woocommerce ul.products.columns-2 li.product,
.woocommerce ul.products.columns-3 li.product,
.woocommerce ul.products.columns-4 li.product,
.woocommerce ul.products.columns-5 li.product,
.woocommerce ul.products.columns-6 li.product {
  float: none !important;
  clear: none !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0;
  margin: 0 !important;
  display: flex;
  flex-direction: column;
}
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
.woocommerce-page ul.products li.product a.woocommerce-LoopProduct-link {
  display: block;
  color: inherit;
  text-decoration: none;
}
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  display: block;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  margin: 0 !important;
  background: var(--kb-bg-alt);
}
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button {
  white-space: normal;
  text-align: center;
  min-height: 44px;
}
@media (max-width: 1100px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 768px) {
  .kb-shop-container { padding-top: 28px; padding-bottom: 48px; }
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
  .woocommerce .woocommerce-ordering,
  .woocommerce .woocommerce-result-count { float: none; width: 100%; }
  .woocommerce .woocommerce-ordering select { width: 100%; }
}
@media (max-width: 480px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: 1fr; }
}
