/**
 * WooCommerce overrides for GameDay Garment theme
 * Loaded only on WooCommerce pages
 */

/* ============================================================
   BASE RESETS
   ============================================================ */

.woocommerce-page .gdg-woo-main {
  padding: 48px var(--pad) 80px;
}

/* ============================================================
   BREADCRUMB
   ============================================================ */

.woocommerce-breadcrumb {
  font-size: 13px;
  color: var(--color-gray-500);
  margin-bottom: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 6px;
  align-items: center;
}
.woocommerce-breadcrumb a {
  color: var(--color-primary);
  transition: color .2s ease;
}
.woocommerce-breadcrumb a:hover { color: var(--color-primary-dk); }

/* ============================================================
   NOTICES
   ============================================================ */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: var(--radius);
  padding: 14px 18px;
  margin-bottom: 20px;
  font-size: 14px;
  border: none;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.woocommerce-message::before { content: '✓'; color: var(--color-primary); font-weight: 700; }
.woocommerce-info::before    { content: 'ℹ'; color: var(--color-primary); font-weight: 700; }
.woocommerce-error::before   { content: '✕'; color: var(--color-accent-red); font-weight: 700; }
.woocommerce-message { background: rgba(30,94,255,.06); color: var(--color-primary); }
.woocommerce-info    { background: var(--color-gray); color: var(--color-black); }
.woocommerce-error   { background: rgba(225,6,0,.06); color: var(--color-accent-red); }

.woocommerce-message .button,
.woocommerce-info .button {
  margin-left: auto !important;
  background: var(--color-primary) !important;
  color: white !important;
  padding: 8px 16px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  border-radius: var(--radius) !important;
}

/* ============================================================
   BUTTONS
   ============================================================ */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .wc-block-components-button,
.woocommerce-page a.button,
.woocommerce-page button.button,
.woocommerce-page input.button {
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  font-family: var(--font-heading) !important;
  font-size: 15px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  border-radius: var(--radius) !important;
  border: 2px solid var(--color-primary) !important;
  padding: 12px 24px !important;
  transition: all .2s ease !important;
  cursor: pointer !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce-page a.button:hover,
.woocommerce-page button.button:hover,
.woocommerce-page input.button:hover {
  background: var(--color-primary-dk) !important;
  border-color: var(--color-primary-dk) !important;
  color: white !important;
  transform: translateY(-1px) !important;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce #payment .place-order .button {
  background: var(--color-navy) !important;
  border-color: var(--color-navy) !important;
  font-size: 18px !important;
  padding: 16px 32px !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: var(--color-navy-dk) !important;
  border-color: var(--color-navy-dk) !important;
}

/* ============================================================
   PRODUCT LOOP (SHOP ARCHIVE)
   ============================================================ */

.woocommerce .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce .products li.product { margin: 0 !important; float: none !important; }

/* Undo WooCommerce clearing */
.woocommerce .products::before,
.woocommerce .products::after { display: none !important; }

/* Product thumbnail */
.woocommerce ul.products li.product a img {
  border-radius: var(--radius-card) var(--radius-card) 0 0 !important;
  transition: transform .3s ease !important;
}
.woocommerce ul.products li.product:hover a img { transform: scale(1.03) !important; }

/* WooCommerce product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-heading) !important;
  font-size: 18px !important;
  letter-spacing: .04em !important;
  color: var(--color-black) !important;
  padding: 14px 16px 4px !important;
  line-height: 1.2 !important;
}

/* Price in loop */
.woocommerce ul.products li.product .price {
  color: var(--color-black) !important;
  font-family: var(--font-heading) !important;
  font-size: 20px !important;
  letter-spacing: .02em !important;
  padding: 0 16px 16px !important;
}
.woocommerce ul.products li.product .price del {
  color: var(--color-gray-500) !important;
  opacity: 1 !important;
  font-size: 14px !important;
  margin-right: 6px !important;
}
.woocommerce ul.products li.product .price ins {
  text-decoration: none !important;
  color: var(--color-accent-red) !important;
}

/* ============================================================
   SALE BADGE
   ============================================================ */

.woocommerce span.onsale {
  background: var(--color-accent-red) !important;
  border-radius: var(--radius-pill) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  min-height: unset !important;
  min-width: unset !important;
  padding: 4px 10px !important;
  line-height: 1.4 !important;
  top: 10px !important;
  left: 10px !important;
  right: auto !important;
}

/* ============================================================
   STAR RATINGS
   ============================================================ */

.woocommerce .star-rating {
  font-size: 14px !important;
  color: var(--color-gold) !important;
}
.woocommerce .star-rating::before { color: var(--color-gray-300) !important; }
.woocommerce .star-rating span::before { color: var(--color-gold) !important; }

/* ============================================================
   SINGLE PRODUCT PAGE
   ============================================================ */

.woocommerce div.product {
  display: block !important;
}
.woocommerce div.product .woocommerce-product-gallery {
  float: none !important;
  width: 100% !important;
}
.woocommerce div.product .summary {
  float: none !important;
  width: 100% !important;
  clear: both !important;
}

/* Summary elements */
.woocommerce div.product .product_title {
  font-family: var(--font-heading) !important;
  font-size: 40px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--color-black) !important;
  margin-bottom: 12px !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--font-heading) !important;
  font-size: 36px !important;
  letter-spacing: .02em !important;
  color: var(--color-black) !important;
  margin-bottom: 20px !important;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
  color: var(--color-gray-500) !important;
  font-size: 22px !important;
  opacity: 1 !important;
}
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
  text-decoration: none !important;
  color: var(--color-accent-red) !important;
}

/* Quantity input */
.woocommerce div.product form.cart div.quantity .qty {
  border: 1.5px solid var(--color-gray-300) !important;
  border-radius: var(--radius) !important;
  padding: 10px 12px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  width: 72px !important;
  text-align: center !important;
}

/* Add to cart button */
.woocommerce div.product form.cart .single_add_to_cart_button {
  font-size: 18px !important;
  padding: 16px 36px !important;
  height: 52px !important;
}

/* Product tabs */
.woocommerce div.product .woocommerce-tabs {
  margin-top: 56px !important;
  border-top: 1px solid var(--color-gray-300) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0 !important;
  margin: 0 0 0 0 !important;
  border-bottom: 2px solid var(--color-gray-300) !important;
  display: flex !important;
  gap: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: none !important;
  background: transparent !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: var(--color-gray-500) !important;
  padding: 14px 24px !important;
  display: block !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -2px !important;
  transition: all .2s ease !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}
.woocommerce div.product .woocommerce-tabs .panel {
  padding: 32px 0 !important;
  margin: 0 !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: var(--color-black) !important;
}

/* Related products */
.woocommerce .related > h2,
.woocommerce .upsells > h2 {
  font-family: var(--font-heading) !important;
  font-size: 32px !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  color: var(--color-black) !important;
  margin-bottom: 28px !important;
}

/* ============================================================
   CHECKOUT
   ============================================================ */

.woocommerce-checkout h3,
.woocommerce-checkout h2 {
  font-family: var(--font-heading) !important;
  font-size: 24px !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  color: var(--color-black) !important;
  margin-bottom: 20px !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid var(--color-primary) !important;
}

.woocommerce-checkout .form-row label {
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  color: var(--color-gray-500) !important;
  margin-bottom: 6px !important;
}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  border: 1.5px solid var(--color-gray-300) !important;
  border-radius: var(--radius) !important;
  padding: 12px 14px !important;
  font-size: 15px !important;
  transition: border-color .2s ease !important;
  width: 100% !important;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
  border-color: var(--color-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(30,94,255,.12) !important;
}

#order_review_heading { display: none !important; }

/* Checkout payment section */
.woocommerce #payment {
  background: var(--color-gray) !important;
  border-radius: var(--radius-card) !important;
  border: 1px solid var(--color-gray-300) !important;
}
.woocommerce #payment .payment_methods li label {
  font-size: 14px !important;
  font-weight: 600 !important;
}

/* ============================================================
   ACCOUNT PAGES
   ============================================================ */

.woocommerce-MyAccount-navigation {
  background: var(--color-navy) !important;
  border-radius: var(--radius-card) !important;
  overflow: hidden !important;
}
.woocommerce-MyAccount-navigation ul { margin: 0 !important; padding: 12px !important; }
.woocommerce-MyAccount-navigation ul li { margin: 0 !important; }
.woocommerce-MyAccount-navigation ul li a {
  display: block !important;
  padding: 11px 16px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: rgba(255,255,255,.7) !important;
  border-radius: var(--radius) !important;
  transition: all .2s ease !important;
}
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover {
  background: rgba(255,255,255,.1) !important;
  color: white !important;
}

/* ============================================================
   PAGINATION
   ============================================================ */

.woocommerce-pagination .page-numbers {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  justify-content: center !important;
  margin-top: 48px !important;
  list-style: none !important;
  padding: 0 !important;
}
.woocommerce-pagination .page-numbers li { margin: 0 !important; }
.woocommerce-pagination .page-numbers li a,
.woocommerce-pagination .page-numbers li span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: var(--radius) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--color-black) !important;
  background: white !important;
  border: 1.5px solid var(--color-gray-300) !important;
  transition: all .2s ease !important;
  text-decoration: none !important;
}
.woocommerce-pagination .page-numbers li a:hover,
.woocommerce-pagination .page-numbers li span.current {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: white !important;
}

/* ============================================================
   RESPONSIVE WOO
   ============================================================ */

@media (max-width: 1024px) {
  .woocommerce .products { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 768px) {
  .woocommerce .products { grid-template-columns: repeat(2, 1fr) !important; gap: 14px !important; }
  .woocommerce div.product .product_title { font-size: 32px !important; }
  .woocommerce div.product p.price { font-size: 28px !important; }
}
@media (max-width: 480px) {
  .woocommerce .products { grid-template-columns: 1fr !important; }
}
