/* ============================================================
   Anakin Labs — WooCommerce overrides
   ============================================================ */

.shop-main { padding: 56px 0 96px; }

.woocommerce-breadcrumb {
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-text-dim);
  margin-bottom: 24px;
}
.woocommerce-breadcrumb a { color: var(--color-text-muted); }

/* ============================================================
   Custom Shop Archive Layout
   ============================================================ */
.shop-head { margin-bottom: 32px; }
.shop-title { font-size: clamp(1.6rem, 3vw, 2.25rem); margin: 6px 0 0; display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.shop-count {
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.shop-layout {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 40px;
  align-items: start;
}
@media (max-width: 900px) {
  .shop-layout { grid-template-columns: 1fr; gap: 32px; }
}

.shop-search { display: flex; gap: 0; }
.shop-search input[type="search"] {
  flex: 1;
  min-width: 0;
  background: var(--color-primary-dk);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  padding: 10px 12px;
  font: inherit;
  font-size: .88rem;
  border-radius: 0;
}
.shop-search input[type="search"]:focus {
  outline: none;
  border-color: var(--color-accent);
}
.shop-search button {
  background: var(--color-accent);
  color: #fff;
  border: 1px solid var(--color-accent);
  padding: 0 14px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
}
.shop-search button:hover { background: var(--color-accent-dk); border-color: var(--color-accent-dk); }

.shop-sidebar {
  position: sticky;
  top: 96px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.shop-filter {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  padding: 20px;
}
.shop-filter-title {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--color-text);
  margin: 0 0 14px;
}
.shop-cats, .shop-links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.shop-cats li a,
.shop-links li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px;
  color: var(--color-text-muted);
  font-size: .88rem;
  border: 1px solid transparent;
  transition: color .15s ease, border-color .15s ease, background .15s ease;
}
.shop-cats li a:hover,
.shop-links li a:hover {
  color: var(--color-text);
  background: rgba(177,39,45,0.08);
}
.shop-cats li.is-active a {
  color: var(--color-text);
  border-color: var(--color-accent);
  background: rgba(177,39,45,0.12);
}
.shop-cats .count {
  font-size: .68rem;
  letter-spacing: .1em;
  color: var(--color-text-dim);
}

/* ==== Shop grid (4 columns, robust) ==== */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}
@media (max-width: 1200px) { .shop-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 900px)  { .shop-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 760px)  { .shop-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 480px)  { .shop-grid { grid-template-columns: 1fr; } }

.shop-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  transition: border-color .2s ease, transform .2s ease;
}
.shop-card:hover { border-color: var(--color-accent); transform: translateY(-2px); }
.shop-card-image {
  display: block;
  aspect-ratio: 1/1;
  background: var(--color-primary-dk);
  position: relative;
  overflow: hidden;
}
.shop-card-image img {
  width: 100%; height: 100%; object-fit: contain; padding: 16px;
  display: block;
}
.shop-card-coa {
  position: absolute;
  top: 10px; right: 10px;
  background: rgba(0,0,0,0.7);
  color: var(--color-accent);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .14em;
  padding: 4px 8px;
  text-transform: uppercase;
  border: 1px solid var(--color-accent);
}
.shop-card-body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.shop-card-title {
  font-weight: 600;
  font-size: 1rem;
  color: var(--color-text);
  text-decoration: none;
  line-height: 1.3;
}
.shop-card-title:hover { color: var(--color-accent); }
.shop-card-sku { font-size: .7rem; letter-spacing: .08em; color: var(--color-text-dim); }
.shop-card-price {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-accent);
  margin-top: 4px;
}
.shop-card-btn {
  margin-top: 12px;
  background: var(--color-accent) !important;
  color: #fff !important;
  border-radius: 0 !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  font-size: .72rem !important;
  padding: 10px 12px !important;
  border: 1px solid var(--color-accent) !important;
  text-align: center;
  display: block;
}
.shop-card-btn.added::after { content: " ✓"; }
.shop-card-btn:hover {
  background: var(--color-accent-dk) !important;
  border-color: var(--color-accent-dk) !important;
}

.shop-pagination { margin-top: 40px; }
.shop-pagination ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: 6px; flex-wrap: wrap; justify-content: center;
}
.shop-pagination li a,
.shop-pagination li span {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: .82rem;
  text-decoration: none;
}
.shop-pagination li span.current { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.shop-pagination li a:hover { color: var(--color-text); border-color: var(--color-accent); }

.woocommerce-products-header__title.page-title {
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 32px;
}

/* Shop archive grid */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
@media (max-width: 1024px) { .woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; } }
@media (max-width: 768px)  { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 480px)  { .woocommerce ul.products { grid-template-columns: 1fr !important; } }

.woocommerce ul.products li.product {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  margin: 0 !important;
  width: auto !important;
  padding: 0 !important;
  float: none !important;
  transition: border-color .2s ease, transform .2s ease;
  display: flex;
  flex-direction: column;
}
.woocommerce ul.products li.product:hover {
  border-color: var(--color-accent);
  transform: translateY(-2px);
}
.woocommerce ul.products li.product a {
  display: flex;
  flex-direction: column;
  color: var(--color-text);
  text-decoration: none;
  flex: 1;
}
.woocommerce ul.products li.product img {
  background: var(--color-primary-dk);
  margin: 0 0 16px;
  padding: 16px;
  aspect-ratio: 1/1;
  object-fit: contain;
  width: 100%;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  padding: 0 20px !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--color-text) !important;
  margin: 0 0 8px !important;
}
.woocommerce ul.products li.product .price {
  padding: 0 20px !important;
  color: var(--color-accent) !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
}
.woocommerce ul.products li.product .button {
  margin: 16px 20px 20px !important;
  background: var(--color-accent) !important;
  color: #fff !important;
  border-radius: 0 !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  font-size: .78rem !important;
  padding: 12px 16px !important;
  border: 1px solid var(--color-accent) !important;
  transition: background .2s ease !important;
}
.woocommerce ul.products li.product .button:hover {
  background: var(--color-accent-dk) !important;
  border-color: var(--color-accent-dk) !important;
}

/* Single product */
.single-product .product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 900px) {
  .single-product .product { grid-template-columns: 1fr; }
}
.single-product .product .images img {
  background: var(--color-surface);
  padding: 32px;
  border: 1px solid var(--color-border);
}
.single-product .product .summary h1 {
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  margin-bottom: 12px;
}
.single-product .product .summary .price {
  color: var(--color-accent) !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  margin-bottom: 20px;
}
.single-product .product .summary .sku_wrapper {
  font-size: .8rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-dim);
}
.single-product .product .summary form.cart {
  display: flex;
  align-items: stretch;
  gap: 10px;
  margin: 20px 0;
}
.single-product .product .summary form.cart .quantity {
  display: flex;
  align-items: stretch;
}
.single-product .product .summary form.cart .quantity input.qty {
  width: 68px !important;
  height: auto !important;
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 0 !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  padding: 0 10px !important;
  text-align: center !important;
  line-height: 1 !important;
}
.single-product .product .summary form.cart .quantity input.qty:focus {
  border-color: var(--color-accent) !important;
  outline: none !important;
}
.single-product .product .summary .single_add_to_cart_button {
  background: var(--color-accent) !important;
  color: #fff !important;
  border-radius: 0 !important;
  padding: 14px 28px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  border: 1px solid var(--color-accent) !important;
  flex: 1;
}
.single-product .product .summary .single_add_to_cart_button:hover {
  background: var(--color-accent-dk) !important;
}

.product-coa-link {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  margin: 18px 0 22px;
  padding: 16px;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  width: 100%;
  box-sizing: border-box;
}
.product-coa-link .btn {
  width: 100%;
  text-align: center;
  white-space: normal;
  word-break: break-word;
  font-size: .72rem;
  letter-spacing: .08em;
  padding: 12px 14px;
  box-sizing: border-box;
}
.product-coa-sku {
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

/* Hide WooCommerce reviews tab and meta */
.woocommerce #reviews,
.woocommerce #tab-reviews,
.woocommerce-tabs li.reviews_tab,
.woocommerce-product-rating,
.woocommerce-review-link,
.comment-reply-title { display: none !important; }

/* Cart + checkout */
.woocommerce-cart-form,
.woocommerce-checkout {
  color: var(--color-text);
}
.woocommerce-cart-form table,
.woocommerce-checkout .shop_table {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
}
.woocommerce .cart_totals {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  padding: 24px;
}
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button {
  background: var(--color-accent) !important;
  color: #fff !important;
  border-radius: 0 !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  padding: 12px 22px !important;
}
.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover {
  background: var(--color-accent-dk) !important;
}

/* Form inputs */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: 0 !important;
  padding: 12px !important;
}

/* Messages */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  background: var(--color-surface) !important;
  border-top: 3px solid var(--color-accent) !important;
  color: var(--color-text) !important;
  border-radius: 0 !important;
}
