/* ===========================
   WooCommerce Global Overrides
   milprep-shop theme
   =========================== */

/* ── General WC resets ── */
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-info {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius);
  color: var(--color-text);
  padding: 14px 20px;
  margin-bottom: 20px;
  font-family: var(--font-body);
  list-style: none;
}
.woocommerce-notices-wrapper .woocommerce-error {
  border-left-color: var(--color-primary);
}
.woocommerce-notices-wrapper .woocommerce-info {
  border-left-color: #3498db;
}

/* ── Buttons ── */
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button,
.woocommerce #respond input#submit,
.woocommerce .button {
  background: var(--color-primary) !important;
  color: #fff !important;
  font-family: var(--font-heading) !important;
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  border: 2px solid var(--color-primary) !important;
  border-radius: var(--radius) !important;
  padding: 10px 22px !important;
  transition: all var(--transition) !important;
  cursor: pointer !important;
  text-decoration: none !important;
}
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce .button:hover {
  background: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
  color: #fff !important;
}
.woocommerce button.button.alt,
.woocommerce a.button.alt {
  background: var(--color-primary) !important;
}

/* Loop add-to-cart button */
.woocommerce-loop-product__link { text-decoration: none; }

/* ── Product loop price ── */
.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product .price ins,
.woocommerce ul.products li.product .price .woocommerce-Price-amount {
  color: var(--color-accent) !important;
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
}
.woocommerce ul.products li.product .price del {
  color: var(--color-text-muted) !important;
  font-size: 0.85rem !important;
}

/* ── Pagination ── */
.woocommerce nav.woocommerce-pagination ul {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px; height: 36px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  font-size: 0.85rem;
  padding: 0 10px;
  transition: all var(--transition);
  text-decoration: none;
}
.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* ── Ordering select ── */
.woocommerce .woocommerce-ordering select {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 0.85rem;
  padding: 6px 12px;
  border-radius: var(--radius);
}

/* ── Result count ── */
.woocommerce-result-count {
  color: var(--color-text-muted) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

/* ── Checkout ── */
.woocommerce-checkout {
  color: var(--color-text);
}
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
}
.woocommerce form .form-row label {
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  color: var(--color-text) !important;
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  padding: 12px !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  outline: none !important;
  border-color: var(--color-primary) !important;
  box-shadow: none !important;
}

/* Order review table */
.woocommerce-checkout-review-order-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
}
.woocommerce-checkout-review-order-table th {
  font-family: var(--font-heading);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-text-muted);
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-darker);
  text-align: left;
}
.woocommerce-checkout-review-order-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: 0.9rem;
}
.woocommerce-checkout-review-order-table .order-total td {
  color: var(--color-accent);
  font-family: var(--font-heading);
  font-size: 1.1rem;
}

/* Payment methods */
.woocommerce-checkout #payment {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 20px;
}
.woocommerce-checkout #payment ul.payment_methods {
  padding: 0;
  list-style: none;
}
.woocommerce-checkout #payment ul.payment_methods li {
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
  font-family: var(--font-body);
}
.woocommerce-checkout #payment ul.payment_methods li label {
  color: var(--color-text);
}
.woocommerce-checkout #payment .payment_box {
  background: var(--color-bg-darker);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 16px;
  margin-top: 10px;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

/* ── My Account ── */
.woocommerce-MyAccount-navigation {
  margin-bottom: 30px;
}
.woocommerce-MyAccount-navigation ul {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
}
.woocommerce-MyAccount-navigation ul li a {
  display: inline-block;
  padding: 8px 18px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all var(--transition);
}
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* ── Star ratings ── */
.woocommerce .star-rating {
  color: var(--color-accent);
}

/* ── Breadcrumbs ── */
.woocommerce-breadcrumb {
  font-size: 0.8rem;
  color: var(--color-text-muted);
}
.woocommerce-breadcrumb a {
  color: var(--color-text-muted);
}
.woocommerce-breadcrumb a:hover {
  color: var(--color-accent);
}

/* ── Quantity input ── */
.woocommerce .quantity .qty {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  color: var(--color-text) !important;
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  padding: 8px 10px !important;
  width: 60px !important;
  text-align: center !important;
}

/* ── Coupon form ── */
.woocommerce .coupon .input-text {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: var(--radius) !important;
  padding: 10px 14px !important;
}

/* ===========================
   My Account — Login & Register forms
   =========================== */

/* Page wrapper */
.woocommerce-account .woo-page-wrap {
  max-width: 960px;
}

/* Two-column split layout → clean stacked cards */
.woocommerce-MyAccount-content,
.u-column1,
.u-column2 {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Wrap both forms in a two-card grid */
.woocommerce-page .col2-set,
.woocommerce .col2-set {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 32px !important;
  float: none !important;
  width: 100% !important;
}

/* Each column becomes a styled card */
.woocommerce .col2-set .col-1,
.woocommerce .col2-set .col-2 {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  padding: 32px !important;
  float: none !important;
  width: 100% !important;
}

/* Section headings */
.woocommerce .col2-set h2 {
  font-family: var(--font-heading) !important;
  font-size: 1.4rem !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  color: var(--color-text) !important;
  margin-bottom: 24px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* Fix the two-column label+input layout → full-width stacked */
.woocommerce form.login .form-row,
.woocommerce form.register .form-row {
  display: flex !important;
  flex-direction: column !important;
  margin-bottom: 18px !important;
  padding: 0 !important;
  float: none !important;
  width: 100% !important;
  clear: both !important;
}

.woocommerce form.login .form-row label,
.woocommerce form.register .form-row label {
  display: block !important;
  font-family: var(--font-heading) !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 8px !important;
  width: 100% !important;
}

/* Full-width inputs */
.woocommerce form.login .form-row .input-text,
.woocommerce form.register .form-row .input-text,
.woocommerce form.login input[type="text"],
.woocommerce form.login input[type="password"],
.woocommerce form.login input[type="email"],
.woocommerce form.register input[type="text"],
.woocommerce form.register input[type="password"],
.woocommerce form.register input[type="email"] {
  width: 100% !important;
  background: var(--color-bg-darker) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  color: var(--color-text) !important;
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  padding: 12px 14px !important;
  box-sizing: border-box !important;
  transition: border-color var(--transition) !important;
}

.woocommerce form.login .form-row .input-text:focus,
.woocommerce form.register .form-row .input-text:focus,
.woocommerce form.login input:focus,
.woocommerce form.register input:focus {
  outline: none !important;
  border-color: var(--color-primary) !important;
  box-shadow: none !important;
}

/* Remember me row */
.woocommerce form.login .form-row.remember-me {
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: 20px !important;
}
.woocommerce form.login .form-row.remember-me label {
  margin-bottom: 0 !important;
  font-size: 0.85rem !important;
  color: var(--color-text-muted) !important;
}

/* Full-width submit buttons */
.woocommerce form.login .form-row.form-row-last,
.woocommerce form.register .form-row.form-row-last {
  margin-top: 8px !important;
}

.woocommerce form.login button[type="submit"],
.woocommerce form.register button[type="submit"],
.woocommerce form.login input[type="submit"],
.woocommerce form.register input[type="submit"] {
  width: 100% !important;
  display: block !important;
  padding: 14px !important;
  font-size: 1rem !important;
  letter-spacing: 2px !important;
}

/* Lost password link */
.woocommerce form.login .lost_password {
  margin-top: 14px !important;
  font-size: 0.85rem !important;
}
.woocommerce form.login .lost_password a {
  color: var(--color-text-muted) !important;
}
.woocommerce form.login .lost_password a:hover {
  color: var(--color-accent) !important;
}

/* Privacy policy text */
.woocommerce form.register .woocommerce-privacy-policy-text {
  font-size: 0.8rem !important;
  color: var(--color-text-muted) !important;
  line-height: 1.6 !important;
  margin-bottom: 16px !important;
  display: block !important;
}

/* Responsive: stack on mobile */
@media (max-width: 640px) {
  .woocommerce .col2-set {
    grid-template-columns: 1fr !important;
  }
}

/* ===========================
   Single product — variation form & add-to-cart
   =========================== */
.single-product-details .cart {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-bottom: 24px;
}
.variations_form .variations {
  width: 100%;
  margin-bottom: 16px;
  border-collapse: collapse;
}
.variations_form .variations tr {
  display: flex;
  flex-direction: column;
  margin-bottom: 16px;
}
.variations_form .variations td,
.variations_form .variations th {
  display: block;
  padding: 0;
  border: none;
  text-align: left;
}
.variations_form .variations label {
  font-family: var(--font-heading) !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 8px !important;
  display: block !important;
}
.variations_form .variations select {
  width: 100% !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  color: var(--color-text) !important;
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  padding: 12px 14px !important;
  cursor: pointer !important;
  transition: border-color var(--transition) !important;
  -webkit-appearance: none !important;
  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='%23ccc' 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;
}
.variations_form .variations select:focus {
  outline: none !important;
  border-color: var(--color-primary) !important;
}
.variations_form .variations select option {
  background: var(--color-bg-card);
  color: var(--color-text);
  padding: 6px;
}
.variations_form .variations select option:checked {
  background: var(--color-primary);
  color: #fff;
}
.reset_variations {
  font-size: 0.75rem !important;
  color: var(--color-text-muted) !important;
  text-decoration: none !important;
  margin-top: 4px !important;
  display: inline-block !important;
}
.reset_variations:hover { color: var(--color-accent) !important; }
.woocommerce-variation-price .price {
  font-family: var(--font-heading) !important;
  font-size: 1.6rem !important;
  color: var(--color-accent) !important;
}
.woocommerce-variation-price .price del {
  color: var(--color-text-muted) !important;
  font-size: 1.1rem !important;
  margin-right: 8px !important;
}
.woocommerce-variation-availability p {
  font-family: var(--font-heading) !important;
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}
.woocommerce-variation-availability .in-stock   { color: #27ae60 !important; }
.woocommerce-variation-availability .out-of-stock { color: var(--color-accent) !important; }
.single-product-details .cart .qty {
  background: var(--color-bg-darker) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  color: var(--color-text) !important;
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  padding: 12px 14px !important;
  width: 70px !important;
  text-align: center !important;
}
.single-product-details .cart .qty:focus {
  outline: none !important;
  border-color: var(--color-primary) !important;
}
.single-product-details .cart button.single_add_to_cart_button,
.single-product-details .cart .single_add_to_cart_button {
  flex: 1 !important;
  padding: 14px 28px !important;
  font-size: 1rem !important;
  letter-spacing: 2px !important;
  min-width: 180px !important;
}
.single-product-details .cart .single_add_to_cart_button.disabled,
.single-product-details .cart .single_add_to_cart_button:disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
}
