/* ============================================================
   WIN v2 — WooCommerce integration
   Maps the dark "WIN v2" design system onto WooCommerce shop,
   product, cart & checkout pages so the whole store is coherent.
   Depends on ds.css (tokens) + layout.css (.card, .flight, .disc…).
   ============================================================ */

/* ---- Shared page wrapper for WooCommerce templates ---- */
.woocommerce-page .wrap.wc-wrap { padding-block: clamp(28px, 5vw, 64px); }
.woocommerce, .woocommerce-page { color: var(--text); }
.woocommerce a { color: var(--text-2); }
.woocommerce a:hover { color: var(--text); }

/* ---- Breadcrumb / result count / ordering ---- */
.woocommerce .woocommerce-breadcrumb { color: var(--muted); font-size: 13.5px; margin-bottom: 22px; }
.woocommerce .woocommerce-result-count { color: var(--muted); }
.woocommerce .woocommerce-ordering select,
.woocommerce select, .woocommerce-page select {
  background: var(--surface); color: var(--text);
  border: 1px solid var(--line-2); border-radius: 999px; padding: 10px 16px;
}

/* ---- Page titles ---- */
.woocommerce-products-header__title,
.woocommerce div.product .product_title,
.woocommerce h1, .woocommerce h2 {
  font-family: 'Saira Condensed', sans-serif; font-weight: 800;
  text-transform: uppercase; letter-spacing: -.01em; color: var(--text);
}

/* ---- Product grid → WIN v2 cards ---- */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid; gap: 22px; margin: 0; padding: 0; list-style: none;
  grid-template-columns: repeat(4, 1fr);
}
/* WooCommerce adds clearfix ::before/::after to ul.products; in a grid they
   become items and occupy the first cell — that was the leading "hole". */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after { content: none; display: none; }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important; margin: 0 !important; padding: 0; float: none; text-align: left;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  overflow: hidden; transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-6px); border-color: var(--line-2); box-shadow: var(--card-shadow);
}
.woocommerce ul.products li.product a img {
  margin: 0; border-radius: 0;
  background: radial-gradient(120% 90% at 50% 0%, rgba(168,85,247,.10), transparent 60%);
  padding: 22px 22px 6px; aspect-ratio: 1; object-fit: contain;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase;
  font-size: 20px; line-height: 1.05; color: var(--text); padding: 0 20px; margin: 4px 0 8px;
}
.woocommerce ul.products li.product .flight { padding: 12px 20px 0; }
.woocommerce ul.products li.product .price {
  display: block; padding: 0 20px 6px; color: #fff !important;
  font-family: 'Saira Condensed', sans-serif; font-weight: 800; font-size: 21px;
}
.woocommerce ul.products li.product .price del { color: var(--muted); font-weight: 600; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
  margin: 0 20px 20px; display: inline-flex;
}
.woocommerce span.onsale {
  background: var(--grad); color: #fff; border-radius: 999px; min-height: 0;
  padding: 6px 12px; font-family: 'Saira Condensed', sans-serif; font-weight: 700;
  letter-spacing: .04em; top: 14px; left: 14px; right: auto;
}

/* ---- Buttons ---- */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce .button.alt {
  background: var(--grad); color: #fff; border: none; border-radius: 999px;
  font-weight: 700; padding: 13px 24px; transition: transform .18s, box-shadow .25s;
  box-shadow: 0 12px 30px -10px rgba(217,70,183,.55);
}
.woocommerce a.button:hover, .woocommerce button.button:hover,
.woocommerce input.button:hover, .woocommerce .button.alt:hover {
  background: var(--grad); transform: translateY(-1px); box-shadow: 0 16px 40px -8px rgba(217,70,183,.85);
}
.woocommerce .button.wc-backward, .woocommerce a.button.alt.disabled { opacity: .6; }

/* ---- Single product ---- */
.woocommerce div.product { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 64px); align-items: start; }
/* Only the gallery + summary are the two columns; everything else (tabs,
   related, upsells) spans the full width — otherwise they get squeezed into a
   single grid column (that's why "Related products" looked narrowed/offset). */
.woocommerce div.product > .woocommerce-tabs,
.woocommerce div.product > .related,
.woocommerce div.product > .upsells,
.woocommerce div.product > .woocommerce-product-gallery + .summary ~ * { grid-column: 1 / -1; }
.woocommerce div.product .images, .woocommerce div.product .summary { float: none; width: auto; margin: 0; }
/* Static single-product image (replaces the JS gallery — see inc/woocommerce.php) */
.woocommerce div.product .wdg-product-image {
  position: relative; margin: 0; border-radius: var(--r-lg); overflow: hidden;
  border: 1px solid var(--line);
  background: radial-gradient(120% 90% at 50% 0%, rgba(168,85,247,.12), transparent 60%);
}
.woocommerce div.product .wdg-product-image .wdg-single-img,
.woocommerce div.product .wdg-product-image img {
  width: 100%; height: auto; display: block; aspect-ratio: 1; object-fit: contain; padding: 24px;
}
.woocommerce div.product .wdg-product-image .onsale {
  top: 14px; left: 14px;
}

/* Flight stats block on the single product page */
.wdg-flightbox {
  margin: 22px 0; padding: 22px; border: 1px solid var(--line); border-radius: var(--r-lg);
  background: linear-gradient(135deg, var(--surface) 0%, var(--bg-2) 100%);
}
.wdg-flightbox-head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  flex-wrap: wrap; margin-bottom: 18px;
}
.wdg-flightbox-head .eyebrow { font-size: 13px; }
.wdg-flightmeters { display: flex; flex-direction: column; gap: 12px; }
.wdg-flightmeter {
  display: grid; grid-template-columns: 90px 32px 1fr; align-items: center; gap: 12px;
}
.wdg-fm-label { font-size: 13.5px; color: var(--text-2); }
.wdg-fm-val {
  font-family: 'Saira Condensed', sans-serif; font-weight: 800; font-size: 18px;
  color: #fff; text-align: center;
}
.wdg-fm-bar { height: 8px; border-radius: 999px; background: var(--surface-3); overflow: hidden; }
.wdg-fm-bar i { display: block; height: 100%; border-radius: 999px; background: var(--grad); }
.woocommerce div.product .product_title { margin-top: 0; font-size: clamp(28px, 3vw, 40px); }
.woocommerce div.product p.price, .woocommerce div.product span.price {
  color: #fff; font-family: 'Saira Condensed', sans-serif; font-weight: 800; font-size: 30px;
}
.woocommerce div.product form.cart { margin-top: 20px; display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.woocommerce div.product .product_meta { margin-top: 18px; font-size: 13px; color: var(--muted); }

/* Quantity input next to add-to-cart (was an unstyled black box) */
.woocommerce .quantity { display: inline-flex; }
.woocommerce .quantity .qty {
  background: var(--surface); color: var(--text); border: 1px solid var(--line-2);
  border-radius: 999px; height: 48px; width: 76px; text-align: center; font-weight: 700; padding: 0 10px;
  -moz-appearance: textfield;
}
.woocommerce .quantity .qty::-webkit-outer-spin-button,
.woocommerce .quantity .qty::-webkit-inner-spin-button { opacity: .5; }

/* ---- Product tabs ---- */
.woocommerce div.product .woocommerce-tabs { margin-top: clamp(36px, 5vw, 64px); clear: both; }
.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex; gap: 8px; padding: 0; margin: 0 0 0; border: none;
  flex-wrap: wrap;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }      /* kill the stray full-width gradient line */
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: var(--surface); border: 1px solid var(--line); border-radius: 999px;
  margin: 0; padding: 0; bottom: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }     /* WC float-tab corner hacks */
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block; padding: 11px 20px; color: var(--text-2); font-weight: 600;
  font-family: 'Saira Condensed', sans-serif; text-transform: uppercase; letter-spacing: .03em;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  background: var(--grad); border-color: transparent;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: #fff; }
.woocommerce div.product .woocommerce-tabs .panel {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 24px 28px; margin-top: 16px;
}
.woocommerce div.product .woocommerce-tabs .panel h2 { font-size: 22px; margin-top: 0; }
.woocommerce #reviews #comments ol.commentlist li .comment-text {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
}

/* Up-sells / related products grid spacing */
.woocommerce .related, .woocommerce .upsells { margin-top: clamp(40px, 5vw, 72px); clear: both; width: 100%; }
.woocommerce .related > h2, .woocommerce .upsells > h2 {
  font-size: clamp(26px, 3vw, 38px); margin-bottom: 26px;
}
/* Related uses ul.products too — keep the 4-up grid full width */
.woocommerce .related ul.products, .woocommerce .upsells ul.products {
  grid-template-columns: repeat(4, 1fr); width: 100%;
}

/* Subcategory tiles (only if a category archive ever shows them) */
.woocommerce ul.products li.product-category { display: flex; flex-direction: column; }
.woocommerce ul.products li.product-category > a { padding: 22px; }
.woocommerce ul.products li.product-category h2 { padding: 0 20px 18px; }

/* ---- Forms (cart, checkout, account) ---- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-page table.cart input, .woocommerce #payment {
  background: var(--surface); color: var(--text);
  border: 1px solid var(--line-2); border-radius: 12px; padding: 12px 14px;
}
.woocommerce table.shop_table {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden;
}
.woocommerce table.shop_table th, .woocommerce table.shop_table td { border-color: var(--line); }
.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce .cart_totals, .woocommerce #order_review {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 18px;
}

/* ---- Notices ---- */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  background: var(--surface-2); border-top: 3px solid var(--violet); color: var(--text);
  border-radius: 0 0 var(--r) var(--r);
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--violet); }
.woocommerce-error { border-top-color: var(--magenta); }

/* ---- Photo product image inside the homepage rails ---- */
.card-media .wdg-photo { display: block; }
.card-media .wdg-prod-img { aspect-ratio: 1; object-fit: contain; width: 100%; }

/* ---- Responsive ---- */
@media (max-width: 1100px) {
  .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 820px) {
  .woocommerce div.product { grid-template-columns: 1fr; }
  .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: 1fr; }
}
