/* ============================================================
   Odyssey Aerials — WooCommerce structural mapping
   Maps WooCommerce default markup onto the Odyssey design system
   and dark-themes shop / product / cart / checkout pages.
   ============================================================ */

/* ---- product loop becomes the Odyssey card grid ---- */
.woocommerce ul.products,
.woocommerce-page ul.products,
ul.products {
  list-style: none;
  margin: 0 !important;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  list-style: none;
}
/* WooCommerce sometimes adds before:clear floats — kill them */
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none !important; }

/* ---- shop page chrome ---- */
.woocommerce-breadcrumb {
  color: var(--text-3);
  font-size: 13px;
  margin-bottom: 22px;
}
.woocommerce-breadcrumb a { color: var(--text-2); }
.woocommerce-breadcrumb a:hover { color: var(--ember-bright); }

.shop-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap; margin-bottom: 28px;
}
.woocommerce-result-count {
  margin: 0 !important; color: var(--text-3); font-size: 13.5px;
}
.woocommerce-ordering { margin: 0 !important; }
.woocommerce-ordering select.orderby {
  appearance: none;
  background: var(--bg-2); border: 1px solid var(--border); color: var(--text-2);
  font-family: var(--font-body); font-size: 13.5px; padding: 10px 34px 10px 14px;
  border-radius: 10px; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237d808c' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
}

/* ---- pagination ---- */
.woocommerce nav.woocommerce-pagination ul {
  border: none; display: flex; gap: 8px; justify-content: center; margin-top: 44px;
}
.woocommerce nav.woocommerce-pagination ul li { border: none; margin: 0; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  min-width: 42px; height: 42px; line-height: 42px; padding: 0 12px;
  background: var(--bg-2); border: 1px solid var(--border); border-radius: 10px;
  color: var(--text-2); font-family: var(--font-display); font-size: 14px;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--ember-wash); border-color: var(--ember); color: var(--ember-bright);
}
.woocommerce nav.woocommerce-pagination ul li a:hover { border-color: var(--text-3); color: var(--text); }

/* ---- notices (cart, errors, info) ---- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
.woocommerce-store-notice {
  background: var(--bg-2) !important;
  border: 1px solid var(--border) !important;
  border-left: 3px solid var(--ember) !important;
  color: var(--text) !important;
  border-radius: var(--radius-sm);
  font-size: 14px;
  padding: 14px 18px !important;
  list-style: none;
}
.woocommerce-error { border-left-color: #e23b2e !important; }
.woocommerce-message a, .woocommerce-info a, .woocommerce-error a { color: var(--ember-bright); }
.woocommerce-message .button,
.woocommerce-info .button { float: right; }

/* ---- generic WooCommerce buttons inherit Odyssey button ---- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-display); font-weight: 600; font-size: 14px;
  padding: 13px 22px; border-radius: 12px; border: 1px solid transparent;
  background: linear-gradient(180deg, var(--ember-bright), var(--ember));
  color: #1a0600 !important;
  box-shadow: 0 0 0 1px rgba(255,90,31,0.4), 0 10px 30px -8px var(--ember-glow);
  text-shadow: none; transition: transform .12s, box-shadow .2s;
  white-space: nowrap; cursor: pointer;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .button:hover { box-shadow: 0 0 0 1px rgba(255,90,31,0.6), 0 14px 38px -8px var(--ember-glow); }
.woocommerce a.button.alt:active,
.woocommerce button.button:active { transform: translateY(1px); }
/* secondary / outline buttons */
.woocommerce a.button.wc-backward,
.woocommerce .cart .button[name="update_cart"],
.woocommerce .button.wp-element-button.disabled {
  background: var(--bg-2); color: var(--text) !important; border-color: var(--border);
  box-shadow: none;
}

/* ---- prices & ratings ---- */
.woocommerce .price,
.woocommerce div.product p.price,
.woocommerce ul.products li.product .price {
  color: var(--text) !important; font-family: var(--font-display); font-weight: 600;
}
.woocommerce .price del { color: var(--text-faint); font-weight: 400; }
.woocommerce .price ins { text-decoration: none; }
.star-rating span::before,
.woocommerce p.stars a::before { color: var(--ember); }
.star-rating::before { color: var(--text-faint); }

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
.single-product div.product { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.single-product .woocommerce-product-gallery { margin: 0 !important; width: 100% !important; }
.single-product .woocommerce-product-gallery__image,
.single-product .woocommerce-product-gallery__wrapper {
  border-radius: var(--radius-lg); overflow: hidden;
}
.single-product div.product .product_title {
  font-family: var(--font-display); font-size: clamp(30px, 4vw, 46px);
  letter-spacing: -0.02em; color: var(--text);
}
.single-product .summary .price { font-size: 28px !important; margin: 8px 0 18px; }
.single-product .summary .woocommerce-product-details__short-description { color: var(--text-2); }
.single-product .cart .quantity input.qty {
  background: var(--bg-2); border: 1px solid var(--border); color: var(--text);
  border-radius: 10px; padding: 12px; width: 72px; font-family: var(--font-display);
}
.single-product .product_meta { color: var(--text-3); font-size: 13px; margin-top: 22px; }
.single-product .product_meta a { color: var(--text-2); }
.woocommerce-tabs ul.tabs { border: none; padding: 0 !important; display: flex; gap: 8px; }
.woocommerce-tabs ul.tabs::before { border: none !important; }
.woocommerce-tabs ul.tabs li {
  background: var(--bg-2) !important; border: 1px solid var(--border) !important;
  border-radius: 99px !important; padding: 0 !important;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.tabs li a {
  font-family: var(--font-display); color: var(--text-2) !important; padding: 9px 18px !important;
}
.woocommerce-tabs ul.tabs li.active { background: var(--ember-wash) !important; border-color: var(--ember) !important; }
.woocommerce-tabs ul.tabs li.active a { color: var(--ember-bright) !important; }
.woocommerce-tabs .panel { color: var(--text-2); }

/* ---- related / upsell headings ---- */
.woocommerce .related > h2,
.woocommerce .upsells > h2,
.woocommerce .cross-sells > h2 {
  font-family: var(--font-display); font-size: 28px; margin-bottom: 24px; color: var(--text);
}

/* ============================================================
   CART & CHECKOUT
   ============================================================ */
.woocommerce table.shop_table {
  border: 1px solid var(--border); border-radius: var(--radius); border-collapse: separate;
  background: var(--surface-card); color: var(--text-2);
}
.woocommerce table.shop_table th { color: var(--text); font-family: var(--font-display); }
.woocommerce table.shop_table td { border-top: 1px solid var(--border); }
.woocommerce-cart table.cart img { width: 64px; border-radius: 8px; }
.woocommerce .cart_totals h2,
.woocommerce-checkout #order_review_heading,
.woocommerce form.checkout h3 { font-family: var(--font-display); color: var(--text); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-container .select2-selection {
  background: var(--bg-2) !important; border: 1px solid var(--border) !important;
  color: var(--text) !important; border-radius: 10px !important; padding: 12px 14px;
}
.woocommerce #payment,
.woocommerce-checkout #payment {
  background: var(--bg-2) !important; border: 1px solid var(--border); border-radius: var(--radius);
}
.woocommerce #payment div.payment_box { background: var(--bg-3) !important; color: var(--text-2); }
.woocommerce-info::before, .woocommerce-message::before { color: var(--ember); }

/* coupon / quantity tweaks */
.woocommerce .coupon input.input-text {
  background: var(--bg-2) !important; border: 1px solid var(--border) !important; color: var(--text) !important;
  border-radius: 10px; padding: 12px 14px;
}

/* ============================================================
   ADD-TO-CART (loop) icon button — matches .add-btn
   ============================================================ */
.woocommerce ul.products li.product a.button.add_to_cart_button,
a.oa-add {
  background: var(--ember-wash) !important;
  border: 1px solid rgba(255,90,31,0.3) !important;
  color: var(--ember-bright) !important;
  box-shadow: none !important;
  padding: 0 16px !important; height: 40px;
}
.woocommerce ul.products li.product a.added_to_cart { display: none; }

/* loading spinner color */
.woocommerce a.button.loading::after { border-color: #1a0600; border-right-color: transparent; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  .woocommerce ul.products, ul.products { grid-template-columns: repeat(3, 1fr); }
  .single-product div.product { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 720px) {
  .woocommerce ul.products, ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 460px) {
  .woocommerce ul.products, ul.products { grid-template-columns: 1fr; }
}
