/* ==========================================================================
   WooCommerce Exact Style Overrides (Cart & Checkout Pages)
   ========================================================================== */

:root {
  --black:   #0a0a0a;
  --off-black: #111111;
  --surface: #161616;
  --surface-2: #1e1e1e;
  --border:  #2a2a2a;
  --border-bright: #3a3a3a;
  --red:     #e8192c;
  --red-dim: #9e111e;
  --white:   #f5f0eb;
  --muted:   #7a7570;
  --accent:  #f0c040;
}

/* Base Body settings for WooCommerce Pages */
.site-woocommerce {
  background: var(--black) !important;
  color: var(--white) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 300 !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
}

/* Entry titles (Cart / Checkout / Account Pages) */
.woocommerce-cart h1.entry-title,
.woocommerce-checkout h1.entry-title,
.woocommerce-account h1.entry-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 80px !important;
  letter-spacing: 6px !important;
  line-height: 1 !important;
  color: var(--white) !important;
  text-align: center !important;
  margin-bottom: 40px !important;
  text-transform: uppercase !important;
  position: relative !important;
  border: none !important;
}

.woocommerce-cart h1.entry-title::after,
.woocommerce-checkout h1.entry-title::after,
.woocommerce-account h1.entry-title::after {
  content: '' !important;
  display: block !important;
  width: 60px !important;
  height: 2px !important;
  background: var(--red) !important;
  margin: 18px auto 0 !important;
}

/* Star Ratings */
.woocommerce .star-rating,
.woocommerce-page .star-rating {
  color: var(--accent) !important;
  margin: 0 auto 10px auto;
}

/* ==========================================================================
   1. Cart Page Overrides
   ========================================================================== */

/* Layout grid columns */
@media (min-width: 861px) {
  .woocommerce-cart .woocommerce {
    display: grid !important;
    grid-template-columns: 1fr 380px !important;
    gap: 32px !important;
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 0 48px 80px !important;
  }
  .woocommerce-cart .woocommerce-cart-form {
    grid-column: 1 !important;
  }
  .woocommerce-cart .cart-collaterals {
    grid-column: 2 !important;
    margin-top: 0 !important;
  }
}

/* Cart Table styling */
.woocommerce-cart table.cart {
  width: 100% !important;
  border-collapse: collapse !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.woocommerce-cart table.cart th {
  font-size: 11px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  font-weight: 400 !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 0 0 14px !important;
  text-align: left !important;
  background: transparent !important;
}

.woocommerce-cart table.cart th:last-child {
  text-align: right !important;
}

.woocommerce-cart table.cart tr.cart_item td {
  padding: 24px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  vertical-align: middle !important;
  background: transparent !important;
}

/* Item Image / Thumbnail */
.woocommerce-cart table.cart td.product-thumbnail img {
  width: 72px !important;
  height: 72px !important;
  object-fit: cover !important;
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
  border-radius: 0 !important;
}

/* Item details & remove button */
.woocommerce-cart table.cart td.product-name a {
  font-size: 15px !important;
  font-weight: 500 !important;
  color: var(--white) !important;
  text-decoration: none !important;
  display: block !important;
  margin-bottom: 4px !important;
}

.woocommerce-cart table.cart td.product-name a:hover {
  color: var(--red) !important;
}

.woocommerce-cart table.cart td.product-remove a.remove {
  color: var(--muted) !important;
  background: transparent !important;
  font-size: 18px !important;
  font-weight: normal !important;
  border: none !important;
  width: auto !important;
  height: auto !important;
  display: inline !important;
}

.woocommerce-cart table.cart td.product-remove a.remove:hover {
  color: var(--red) !important;
  background: transparent !important;
}

/* Quantity controls override */
.woocommerce-cart table.cart td.product-quantity .quantity,
.woocommerce div.product .quantity {
  display: inline-flex !important;
  align-items: center !important;
  border: 1px solid var(--border-bright) !important;
  background: var(--surface) !important;
  height: 36px !important;
}

.woocommerce-cart table.cart td.product-quantity .quantity input.qty,
.woocommerce div.product .quantity input.qty {
  width: 50px !important;
  height: 34px !important;
  border: none !important;
  background: transparent !important;
  color: var(--white) !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  padding: 0 !important;
  outline: none !important;
}

/* Table pricing items */
.woocommerce-cart table.cart td.product-price span,
.woocommerce-cart table.cart td.product-subtotal span {
  font-size: 16px !important;
  font-weight: 500 !important;
  color: var(--white) !important;
}

.woocommerce-cart table.cart td.product-subtotal {
  text-align: right !important;
}

/* Coupon Wrapper & Form in Actions */
.woocommerce-cart-form td.actions {
  padding: 24px 0 0 0 !important;
  background: transparent !important;
  border: none !important;
}

.woocommerce-cart-form td.actions .coupon {
  float: left !important;
  display: inline-flex !important;
  gap: 0 !important;
  border: 1px solid var(--border) !important;
  padding: 14px 16px !important;
  background: var(--off-black) !important;
}

.woocommerce-cart-form td.actions .coupon label {
  display: none !important;
}

.woocommerce-cart-form td.actions .coupon input.input-text {
  background: var(--surface) !important;
  border: 1px solid var(--border-bright) !important;
  border-right: none !important;
  color: var(--white) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
  padding: 9px 14px !important;
  outline: none !important;
  border-radius: 0 !important;
  width: 150px !important;
  height: 38px !important;
}

.woocommerce-cart-form td.actions .coupon button.button {
  background: var(--red) !important;
  color: #fff !important;
  border: none !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 14px !important;
  letter-spacing: 1.5px !important;
  padding: 0 18px !important;
  cursor: pointer !important;
  transition: background .15s !important;
  border-radius: 0 !important;
  height: 38px !important;
  line-height: 38px !important;
}

.woocommerce-cart-form td.actions .coupon button.button:hover {
  background: #c7151f !important;
}

/* Continue Shopping & Update Cart actions */
.woocommerce-cart-form td.actions button.button[name="update_cart"] {
  float: right !important;
  background: none !important;
  border: 1px solid var(--border-bright) !important;
  color: var(--muted) !important;
  font-size: 12px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 10px 20px !important;
  cursor: pointer !important;
  transition: all .2s !important;
  border-radius: 0 !important;
  height: 38px !important;
  line-height: 36px !important;
  font-weight: normal !important;
}

.woocommerce-cart-form td.actions button.button[name="update_cart"]:hover {
  color: var(--white) !important;
  border-color: var(--white) !important;
  background: transparent !important;
}

/* Sidebar Order Summary Box (Cart) */
.woocommerce-cart .cart-collaterals .cart_totals {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  padding: 28px !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  width: 100% !important;
  float: none !important;
}

.woocommerce-cart .cart-collaterals .cart_totals h2 {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 22px !important;
  letter-spacing: 3px !important;
  color: var(--white) !important;
  margin-bottom: 22px !important;
  text-transform: uppercase !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

.woocommerce-cart .cart-collaterals .cart_totals table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin-bottom: 22px !important;
  border: none !important;
  background: transparent !important;
}

.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tr th,
.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tr td {
  padding: 10px 0 !important;
  font-size: 14px !important;
  color: var(--muted) !important;
  border-bottom: 1px solid var(--border) !important;
  background: transparent !important;
  border-top: none !important;
  text-align: left !important;
}

.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tr.order-total th,
.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tr.order-total td {
  padding-top: 16px !important;
  margin-top: 4px !important;
  color: var(--white) !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  border-top: 1px solid var(--border) !important;
  border-bottom: none !important;
}

.woocommerce-cart .cart-collaterals .cart_totals table.shop_table tr.order-total td span.woocommerce-Price-amount {
  font-size: 22px !important;
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 1px !important;
  color: var(--accent) !important;
}

/* Checkout CTA Button in Cart */
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  display: block !important;
  width: 100% !important;
  background: var(--red) !important;
  color: #fff !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 20px !important;
  letter-spacing: 3px !important;
  border: none !important;
  padding: 16px !important;
  cursor: pointer !important;
  transition: background .2s !important;
  margin-top: 22px !important;
  border-radius: 0 !important;
  text-align: center !important;
  line-height: 1 !important;
  box-shadow: none !important;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
  background: #c7151f !important;
}


/* ==========================================================================
   2. Checkout Page Overrides
   ========================================================================== */

/* Grid layout checkout columns */
@media (min-width: 861px) {
  .woocommerce-checkout form.checkout {
    display: grid !important;
    grid-template-columns: 1fr 380px !important;
    gap: 32px !important;
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 0 48px 80px !important;
  }
  .woocommerce-checkout #customer_details {
    grid-column: 1 !important;
    float: none !important;
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    box-shadow: none !important;
  }
  .woocommerce-checkout #order_review_wrapper {
    grid-column: 2 !important;
  }
}

/* Col-1 and Col-2 stacked forms structure */
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
  float: none !important;
  width: 100% !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin-bottom: 30px !important;
}

/* Section titles */
.woocommerce-checkout h3 {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 20px !important;
  letter-spacing: 3px !important;
  color: var(--white) !important;
  margin-bottom: 18px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  text-transform: uppercase !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

.woocommerce-checkout h3::after {
  content: '' !important;
  flex: 1 !important;
  height: 1px !important;
  background: var(--border) !important;
}

/* Form row elements styling */
.woocommerce-checkout .form-row {
  margin-bottom: 14px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}

.woocommerce-checkout .form-row label {
  font-size: 11px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  font-weight: normal !important;
}

.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--white) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  padding: 11px 14px !important;
  outline: none !important;
  transition: border-color .2s !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
  border-color: var(--red) !important;
}

/* Custom dropdown icon for select elements */
.woocommerce-checkout select {
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a7570' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  padding-right: 36px !important;
}

.woocommerce-checkout select option {
  background: var(--surface) !important;
}

/* Right-side checkout summary cards */
.woocommerce-checkout #order_review {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  padding: 28px !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#order_review_heading {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 22px !important;
  letter-spacing: 3px !important;
  color: var(--white) !important;
  margin-bottom: 18px !important;
  text-transform: uppercase !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

/* Checkout table lines */
.woocommerce-checkout table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  background: transparent !important;
  border: none !important;
  margin-bottom: 22px !important;
}

.woocommerce-checkout table.shop_table th {
  display: none !important; /* Hide column headings as order line is fully intuitive */
}

.woocommerce-checkout table.shop_table td {
  padding: 14px 0 !important;
  border-top: none !important;
  border-bottom: 1px solid var(--border) !important;
  background: transparent !important;
}

.woocommerce-checkout table.shop_table tr.cart_item td.product-name {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--white) !important;
  text-align: left !important;
}

.woocommerce-checkout table.shop_table tr.cart_item td.product-total {
  text-align: right !important;
}

.woocommerce-checkout table.shop_table tr.cart_item td.product-total span {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--white) !important;
}

/* Order Totals */
.woocommerce-checkout table.shop_table tr.cart-subtotal th,
.woocommerce-checkout table.shop_table tr.cart-subtotal td,
.woocommerce-checkout table.shop_table tr.shipping th,
.woocommerce-checkout table.shop_table tr.shipping td,
.woocommerce-checkout table.shop_table tr.tax th,
.woocommerce-checkout table.shop_table tr.tax td {
  font-size: 13px !important;
  color: var(--muted) !important;
  padding: 8px 0 !important;
  border-top: none !important;
  border-bottom: none !important;
  background: transparent !important;
}

.woocommerce-checkout table.shop_table tr.cart-subtotal th,
.woocommerce-checkout table.shop_table tr.shipping th,
.woocommerce-checkout table.shop_table tr.tax th {
  text-align: left !important;
}

.woocommerce-checkout table.shop_table tr.cart-subtotal td,
.woocommerce-checkout table.shop_table tr.shipping td,
.woocommerce-checkout table.shop_table tr.tax td {
  text-align: right !important;
}

.woocommerce-checkout table.shop_table tr.order-total th,
.woocommerce-checkout table.shop_table tr.order-total td {
  color: var(--white) !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  border-top: 1px solid var(--border) !important;
  border-bottom: none !important;
  margin-top: 8px !important;
  padding-top: 14px !important;
  background: transparent !important;
}

.woocommerce-checkout table.shop_table tr.order-total th {
  text-align: left !important;
}

.woocommerce-checkout table.shop_table tr.order-total td {
  text-align: right !important;
}

.woocommerce-checkout table.shop_table tr.order-total td span.woocommerce-Price-amount {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 24px !important;
  letter-spacing: 1px !important;
  color: var(--accent) !important;
}

/* Payment Methods & Gateways (Checkout) */
.woocommerce-checkout #payment {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin-top: 28px !important;
}

.woocommerce-checkout #payment ul.payment_methods {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.woocommerce-checkout #payment ul.payment_methods li {
  border: 1px solid var(--border) !important;
  background: var(--surface) !important;
  padding: 16px 18px !important;
  transition: all .2s !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

.woocommerce-checkout #payment ul.payment_methods li:hover {
  border-color: var(--border-bright) !important;
}

/* Checked Payment state */
.woocommerce-checkout #payment ul.payment_methods li:has(input[type="radio"]:checked) {
  border-color: var(--red) !important;
  background: rgba(232, 25, 44, 0.05) !important;
}

.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
  accent-color: var(--red) !important;
  margin-right: 14px !important;
}

.woocommerce-checkout #payment ul.payment_methods li label {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--white) !important;
  cursor: pointer !important;
}

.woocommerce-checkout #payment ul.payment_methods li .payment_box {
  background: var(--surface-2) !important;
  color: var(--muted) !important;
  border: 1px solid var(--border) !important;
  padding: 12px 14px !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  margin-top: 10px !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Main Checkout Submit Button */
.woocommerce-checkout #place_order {
  display: block !important;
  width: 100% !important;
  background: var(--red) !important;
  color: #fff !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 20px !important;
  letter-spacing: 3px !important;
  border: none !important;
  padding: 16px !important;
  cursor: pointer !important;
  transition: background .2s !important;
  margin-top: 28px !important;
  border-radius: 0 !important;
  text-align: center !important;
  box-shadow: none !important;
  line-height: 1 !important;
}

.woocommerce-checkout #place_order:hover {
  background: #c7151f !important;
}


/* ==========================================================================
   3. Product Details & Archive Cards
   ========================================================================== */

/* Single Product detail card */
.woocommerce div.product,
.woocommerce-page div.product {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 40px !important;
  box-shadow: none !important;
  margin-top: 30px !important;
  margin-bottom: 60px !important;
}

.woocommerce div.product .product_title,
.woocommerce-page div.product .product_title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 54px !important;
  color: var(--white) !important;
  line-height: 1.05 !important;
  margin-bottom: 15px !important;
  letter-spacing: 0.02em !important;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price,
.woocommerce-page div.product p.price,
.woocommerce-page div.product span.price {
  color: var(--accent) !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  margin-bottom: 25px !important;
}

.woocommerce div.product .woocommerce-product-details__short-description,
.woocommerce-page div.product .woocommerce-product-details__short-description {
  color: rgba(255, 255, 255, 0.7) !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
  margin-bottom: 30px !important;
}

/* Loop product cards */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 25px !important;
  text-align: center !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
  margin-bottom: 35px !important;
  box-shadow: none !important;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  border-color: rgba(200, 16, 46, 0.4) !important;
  transform: translateY(-4px) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-category__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 26px !important;
  color: var(--white) !important;
  margin: 18px 0 8px 0 !important;
  letter-spacing: 0.04em !important;
  line-height: 1.1 !important;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  color: var(--accent) !important;
  font-size: 19px !important;
  margin-bottom: 18px !important;
}

.woocommerce ul.products li.product .price del,
.woocommerce-page ul.products li.product .price del {
  color: var(--muted) !important;
  font-size: 14px !important;
}

.woocommerce ul.products li.product .price ins,
.woocommerce-page ul.products li.product .price ins {
  text-decoration: none !important;
  color: var(--accent) !important;
}

/* Catalog sorting header override */
.woocommerce-before-shop-loop {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 20px !important;
  margin-bottom: 45px !important;
  border-bottom: 1px solid var(--border) !important;
  padding-bottom: 25px !important;
}

.woocommerce-ordering select {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--white) !important;
  padding: 10px 16px !important;
  border-radius: 0 !important;
  outline: none !important;
  cursor: pointer !important;
}

/* System Alerts / Banners override */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  background-color: var(--surface) !important;
  border-top-color: var(--red) !important;
  color: var(--white) !important;
  border-radius: 0 !important;
  padding: 18px 24px !important;
  box-shadow: none !important;
}

.woocommerce-message a.button,
.woocommerce-info a.button {
  background: var(--surface-2) !important;
  color: var(--white) !important;
  border-radius: 0 !important;
  padding: 10px 20px !important;
  font-size: 12px !important;
  font-weight: bold !important;
  text-transform: uppercase !important;
  border: 1px solid var(--border) !important;
}

.woocommerce-message a.button:hover,
.woocommerce-info a.button:hover {
  background: var(--red) !important;
  border-color: var(--red) !important;
}
