/**
 * InnoSewa – WooCommerce Supplemental Styles
 * Loaded only when WooCommerce is active.
 */

/* ============================================================
   PRODUCT GRID — global override of WooCommerce's float layout
   ============================================================ */

/* Container: replace floats with CSS Grid everywhere — 3 columns for large, premium cards */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 28px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
  clear: both !important;
}

/* Related / upsells — 3 cols, one clean row */
.woocommerce .related > ul.products,
.woocommerce .upsells > ul.products {
  grid-template-columns: repeat(3, 1fr) !important;
}

/* Responsive columns */
@media (max-width: 900px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 540px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: 1fr !important; }
}

/* ============================================================
   PRODUCT LOOP (archive / shop page)
   ============================================================ */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--white);
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid rgba(200,144,42,.12);
  transition: all var(--transition);
  display: flex;
  flex-direction: column;
  /* Override WooCommerce float-based width */
  width: auto !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
  border-color: rgba(200,144,42,.3);
}

.woocommerce ul.products li.product a img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.woocommerce ul.products li.product:hover a img {
  transform: scale(1.05);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  padding: 16px 16px 4px !important;
  font-family: var(--font-display) !important;
  font-size: 1.05rem !important;
  color: var(--tobacco) !important;
  font-weight: 600 !important;
}

.woocommerce ul.products li.product .price {
  padding: 0 16px 12px !important;
  font-family: var(--font-mono) !important;
  font-size: .95rem !important;
  color: var(--tobacco) !important;
  font-weight: 600 !important;
}

.woocommerce ul.products li.product .button {
  display: block !important;
  margin: 0 16px 16px !important;
  text-align: center !important;
}

/* On sale badge */
.woocommerce ul.products li.product .onsale {
  background: var(--red) !important;
  border-radius: var(--r-pill) !important;
  font-size: .7rem !important;
  font-weight: 700 !important;
  padding: 4px 10px !important;
  min-width: auto !important;
  min-height: auto !important;
  line-height: 1 !important;
}

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
.woocommerce div.product {
  padding: 0 !important;
}

/* Clearfix — ensures .related section sits below the image/summary float columns */
.woocommerce div.product::after {
  content: '';
  display: table;
  clear: both;
}

/* Related & upsells section spacing */
.woocommerce .related,
.woocommerce .upsells {
  margin-top: 64px !important;
  padding-top: 48px !important;
  border-top: 1px solid rgba(200,144,42,.15) !important;
  clear: both !important;
  width: 100% !important;
  display: block !important;
}

.woocommerce .related h2,
.woocommerce .upsells h2 {
  font-family: var(--font-display) !important;
  font-size: 1.75rem !important;
  color: var(--tobacco) !important;
  margin-bottom: 32px !important;
}

/* ── Related / upsell product grid — ultra-specific, 3 columns, one clean row ── */
.woocommerce .related.products > ul.products,
.woocommerce .upsells.products > ul.products,
.woocommerce-page .related.products > ul.products,
.woocommerce-page .upsells.products > ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 28px !important;
  width: 100% !important;
  float: none !important;
  clear: both !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.woocommerce .related.products > ul.products > li.product,
.woocommerce .upsells.products > ul.products > li.product,
.woocommerce-page .related.products > ul.products > li.product,
.woocommerce-page .upsells.products > ul.products > li.product {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

@media (max-width: 900px) {
  .woocommerce .related.products > ul.products,
  .woocommerce .upsells.products > ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 540px) {
  .woocommerce .related.products > ul.products,
  .woocommerce .upsells.products > ul.products { grid-template-columns: 1fr !important; }
}

.woocommerce div.product div.images .woocommerce-product-gallery__wrapper {
  border-radius: var(--r-xl);
  overflow: hidden;
}

.woocommerce div.product div.summary .price {
  font-family: var(--font-mono) !important;
  font-size: 1.6rem !important;
  color: var(--tobacco) !important;
  font-weight: 700 !important;
}

.woocommerce div.product div.summary .woocommerce-product-rating {
  margin-bottom: var(--sp-md) !important;
}

.woocommerce div.product form.cart {
  display: flex;
  gap: var(--sp-md);
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: var(--sp-xl) !important;
}

.woocommerce div.product form.cart .quantity input {
  border-radius: var(--r-md) !important;
  border: 1.5px solid var(--smoke) !important;
  padding: 10px 12px !important;
  font-family: var(--font-mono) !important;
  font-size: 1rem !important;
  width: 80px !important;
  text-align: center;
}

.woocommerce div.product form.cart div.quantity { margin-bottom: 0 !important; }

/* Product tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0 !important;
  border-bottom: 2px solid var(--smoke) !important;
  background: none !important;
  display: flex;
  gap: 4px;
  list-style: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: none !important;
  border-radius: 0 !important;
  background: none !important;
  margin: 0 !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-body) !important;
  font-size: .9rem !important;
  font-weight: 500 !important;
  color: var(--ash) !important;
  padding: 10px 20px !important;
  display: block;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -2px !important;
  transition: all var(--transition) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--gold) !important;
  border-bottom-color: var(--gold) !important;
}

.woocommerce div.product .woocommerce-tabs .panel {
  padding: var(--sp-xl) 0 !important;
}

/* Cigar meta grid */
.cigar-meta-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-sm);
  margin: var(--sp-lg) 0;
  padding: var(--sp-lg);
  background: var(--parchment);
  border-radius: var(--r-lg);
  border: 1px solid rgba(200,144,42,.15);
}

.cigar-meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.cigar-meta-label {
  font-size: .68rem;
  font-weight: 700;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .1em;
}

.cigar-meta-value {
  font-size: .9rem;
  color: var(--tobacco);
  font-weight: 500;
}

.strength-display {
  margin: var(--sp-md) 0;
  display: flex;
  align-items: center;
  gap: var(--sp-md);
}

.strength-label {
  font-size: .8rem;
  font-weight: 600;
  color: var(--ash);
  min-width: 60px;
}

/* ============================================================
   CART PAGE
   ============================================================ */
.woocommerce table.cart {
  border-radius: var(--r-lg) !important;
  overflow: hidden !important;
  border: 1px solid rgba(200,144,42,.15) !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

.woocommerce table.cart thead th {
  background: var(--tobacco) !important;
  color: var(--cream) !important;
  font-family: var(--font-body) !important;
  font-size: .8rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  padding: 14px 16px !important;
  border: none !important;
}

.woocommerce table.cart td {
  padding: 16px !important;
  border-color: rgba(200,144,42,.1) !important;
  vertical-align: middle !important;
}

.woocommerce table.cart td.product-name a {
  font-family: var(--font-display) !important;
  font-size: 1.05rem !important;
  color: var(--tobacco) !important;
  font-weight: 600 !important;
}

.woocommerce .wc-proceed-to-checkout .checkout-button {
  background: var(--tobacco) !important;
  color: var(--cream) !important;
  padding: 16px 40px !important;
  font-size: 1rem !important;
  border-radius: var(--r-lg) !important;
  width: 100% !important;
}

.woocommerce .wc-proceed-to-checkout .checkout-button:hover {
  background: var(--espresso) !important;
  color: var(--cream) !important;
}

/* ============================================================
   CHECKOUT PAGE
   ============================================================ */
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout h3 {
  font-family: var(--font-display) !important;
  font-size: 1.4rem !important;
  color: var(--tobacco) !important;
  margin-bottom: var(--sp-lg) !important;
}

.woocommerce-checkout #payment {
  background: var(--parchment) !important;
  border-radius: var(--r-xl) !important;
  border: 1px solid rgba(200,144,42,.15) !important;
}

.woocommerce #payment div.payment_box {
  background: var(--white) !important;
}

.woocommerce #payment div.payment_box::before {
  border-bottom-color: var(--white) !important;
}

.woocommerce #place_order {
  background: var(--gold) !important;
  color: var(--tobacco) !important;
  font-size: 1.05rem !important;
  padding: 16px 40px !important;
  border-radius: var(--r-lg) !important;
  width: 100% !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
}

.woocommerce #place_order:hover {
  background: var(--honey) !important;
  color: var(--tobacco) !important;
}

/* ============================================================
   MY ACCOUNT
   ============================================================ */
.woocommerce-MyAccount-navigation {
  background: var(--white) !important;
  border-radius: var(--r-xl) !important;
  padding: var(--sp-lg) !important;
  border: 1px solid rgba(200,144,42,.15) !important;
}

.woocommerce-MyAccount-navigation ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }

.woocommerce-MyAccount-navigation ul li {
  border: none !important;
  background: none !important;
}

.woocommerce-MyAccount-navigation ul li a {
  display: block !important;
  padding: 10px 14px !important;
  border-radius: var(--r-md) !important;
  color: var(--espresso) !important;
  font-size: .9rem !important;
  font-weight: 500 !important;
  transition: all var(--transition) !important;
  text-decoration: none !important;
}

.woocommerce-MyAccount-navigation ul li:hover a,
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: rgba(200,144,42,.1) !important;
  color: var(--gold) !important;
}

.woocommerce-MyAccount-content .woocommerce-orders-table {
  border-radius: var(--r-lg) !important;
  overflow: hidden !important;
  border: 1px solid rgba(200,144,42,.12) !important;
}

.woocommerce-MyAccount-content .woocommerce-orders-table__header {
  background: var(--tobacco) !important;
  color: var(--cream) !important;
}

/* ============================================================
   WHOLESALE USER – DASHBOARD
   ============================================================ */
.wholesale-dash-wrapper {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--sp-xl);
  align-items: start;
}

.wholesale-dash-nav {
  background: var(--white);
  border-radius: var(--r-xl);
  padding: var(--sp-lg);
  border: 1px solid rgba(200,144,42,.15);
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: sticky;
  top: 100px;
}

.dash-nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: 10px 14px;
  border-radius: var(--r-md);
  color: var(--espresso);
  font-size: .9rem;
  font-weight: 500;
  text-decoration: none;
  transition: all var(--transition);
}

.dash-nav-item:hover,
.dash-nav-item.active {
  background: rgba(200,144,42,.1);
  color: var(--gold);
}

.dash-nav-icon { font-size: 1.1rem; }

/* Wholesale pricing badge on products */
.wholesale-price-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  background: rgba(200,144,42,.15);
  color: var(--gold);
  border-radius: var(--r-pill);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 1px solid rgba(200,144,42,.3);
  margin-top: 4px;
}

@media (max-width: 768px) {
  .wholesale-dash-wrapper { grid-template-columns: 1fr; }
  .wholesale-dash-nav { position: static; flex-direction: row; flex-wrap: wrap; }
  .cigar-meta-grid { grid-template-columns: 1fr 1fr; }
}
