/* ============================================================
   APM THEME — WOOCOMMERCE CSS
   Conditional: loaded on shop / product / category pages only
   ============================================================ */

/* ── Font: force WooCommerce to inherit theme font system ──────
 *
 * WooCommerce's own stylesheet hard-codes several font-family values.
 * The rules below override every WC surface to use our CSS variable.
 * Specificity trick: we use the same selectors WC uses, so we win
 * without needing !important.
 *
 * Fallback value mirrors --font-base so this still works even if
 * the CSS variable is not yet parsed (e.g. old browser, cached CSS).
 * ──────────────────────────────────────────────────────────────── */
.woocommerce,
.woocommerce-page,
.woocommerce *,
.woocommerce-page * {
  font-family: var(--font-base, 'Be Vietnam Pro', system-ui, sans-serif);
}

/*
 * WooCommerce sets font-family on these elements explicitly.
 * Re-declare them to ensure inheritance from our root variable.
 */
.woocommerce .product_title,
.woocommerce div.product p.price,
.woocommerce div.product span.price,
.woocommerce-tabs .panel,
.woocommerce-tabs ul.tabs li a,
.woocommerce table.shop_table,
.woocommerce form .form-row label,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-checkout #order_review,
.woocommerce-cart-form,
.woocommerce .cart_totals,
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  font-family: var(--font-base, 'Be Vietnam Pro', system-ui, sans-serif);
}

.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count { float: none; margin: 0; font-size: 14px; }

.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering { float: none; margin: 0; }

.woocommerce-page .site-header__brand,
.woocommerce-page .site-header__logo-link {
  flex: 0 0 auto;
  width: auto;
  max-width: none;
}

.woocommerce-page .site-header__logo-link .site-header__logo-img {
  display: block;
  width: auto !important;
  height: 48px !important;
  max-width: 260px !important;
  max-height: 48px !important;
  object-fit: contain;
}

/* Remove WC default grid */
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none; }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product { float: none; width: auto; margin: 0; }

/* ── Notices ─────────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
    padding: 14px 20px 14px 50px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 20px;
    position: relative;
    list-style: none;
}
.woocommerce-message {
    background: #ecfdf5;
    border-left: 4px solid #10b981;
    color: #065f46;
}
.woocommerce-error {
    background: #fef2f2;
    border-left: 4px solid #ef4444;
    color: #991b1b;
}
.woocommerce-info {
    background: #eff6ff;
    border-left: 4px solid #3b82f6;
    color: #1e40af;
}
.woocommerce-message::before { content: '✓'; position: absolute; left: 18px; font-weight: 700; color: #10b981; }
.woocommerce-error::before   { content: '✕'; position: absolute; left: 18px; font-weight: 700; color: #ef4444; }
.woocommerce-info::before    { content: 'ℹ'; position: absolute; left: 16px; font-weight: 700; color: #3b82f6; }
.woocommerce-message a,
.woocommerce-error a,
.woocommerce-info a { color: inherit; text-decoration: underline; font-weight: 600; }

/* ── Star Ratings ────────────────────────────────────────────── */
.woocommerce .star-rating { color: #f59e0b; font-size: 13px; }
.woocommerce .star-rating span { color: #f59e0b; }
.woocommerce .woocommerce-product-rating { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.woocommerce .woocommerce-review-link { font-size: 13px; color: var(--clr-text-light, #6b7280); }

/* ── WooCommerce Tabs (single product) ───────────────────────── */
.woocommerce div.product .woocommerce-tabs { display: none; } /* custom tabs used instead */

/* ── Product Images ──────────────────────────────────────────── */
.woocommerce div.product div.images { margin-bottom: 0; }
.woocommerce div.product div.images .woocommerce-product-gallery__image--placeholder {
    border: none;
    background: var(--clr-bg-alt, #f8f9fa);
    border-radius: 12px;
}
.woocommerce div.product div.images figure img { border-radius: 12px; }
.woocommerce .flex-viewport { border-radius: 12px; overflow: hidden; }

/* ── Sale Badge ──────────────────────────────────────────────── */
.woocommerce span.onsale {
    display: none; /* B2B: no pricing, hide sale badge */
}

/* ── WC Buttons (override) ───────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--clr-primary, #054b9e);
    color: #fff !important;
    border: 2px solid var(--clr-primary, #054b9e);
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: background .2s, border-color .2s;
    text-decoration: none;
    line-height: 1;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background: var(--clr-primary-dark, #03337a);
    border-color: var(--clr-primary-dark, #03337a);
    color: #fff !important;
}
.woocommerce a.button.alt,
.woocommerce button.button.alt {
    background: var(--clr-accent, #e63946);
    border-color: var(--clr-accent, #e63946);
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background: var(--clr-accent-dark, #c1121f);
    border-color: var(--clr-accent-dark, #c1121f);
}

/* ── Quantity input ──────────────────────────────────────────── */
.woocommerce .quantity .qty {
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: 10px 12px;
    font-size: 15px;
    width: 70px;
    text-align: center;
}

/* ── Product loop: clear WC float layout ─────────────────────── */
.woocommerce-page ul.products {
    display: grid;
    gap: 24px;
    margin: 0;
    padding: 0;
}
.woocommerce-page ul.products li.product { list-style: none; }

/* ── Archive: product count result text ──────────────────────── */
.woocommerce-result-count { font-size: 14px; color: var(--clr-text-light, #6b7280); margin: 0; }

/* ── Pagination ──────────────────────────────────────────────── */
.woocommerce nav.woocommerce-pagination ul {
    display: flex;
    gap: 8px;
    justify-content: center;
    border: none;
    margin: 0;
    padding: 0;
}
.woocommerce nav.woocommerce-pagination ul li { border: none; padding: 0; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--clr-text, #1a1a2e);
    background: #fff;
    transition: background .15s, border-color .15s, color .15s;
    text-decoration: none;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--clr-primary, #054b9e);
    border-color: var(--clr-primary, #054b9e);
    color: #fff;
}

/* ── Product categories section ──────────────────────────────── */
.woocommerce ul.products.columns-3 { grid-template-columns: repeat(3, 1fr); }
.woocommerce ul.products.columns-4 { grid-template-columns: repeat(4, 1fr); }

/* ── Related products ────────────────────────────────────────── */
.related-products { padding-top: 48px; }
.related-products__title {
    font-size: clamp(20px, 2.5vw, 28px);
    font-weight: 800;
    margin-bottom: 32px;
    color: var(--clr-text, #1a1a2e);
    padding-bottom: 16px;
    border-bottom: 2px solid var(--clr-border, #e5e7eb);
}
.related-products__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

/* ── Cross-sells / Upsells ───────────────────────────────────── */
.woocommerce .cross-sells,
.woocommerce .upsells { display: none; } /* hidden for B2B focus */

/* ── Single product: WC default summary overrides ────────────── */
.woocommerce div.product .product_title { display: none; } /* custom H1 used */
.woocommerce div.product p.price,
.woocommerce div.product span.price { display: none !important; } /* no pricing B2B */
.woocommerce div.product .woocommerce-product-details__short-description { display: none; } /* custom */
.woocommerce div.product form.cart { display: none; } /* no cart */

/* ── Breadcrumb in WooCommerce ───────────────────────────────── */
.woocommerce .woocommerce-breadcrumb { display: none; } /* custom breadcrumb used */

/* ── WC form fields (contact/checkout forms) ─────────────────── */
.woocommerce form .form-row label { font-size: 13px; font-weight: 600; color: var(--clr-text, #1a1a2e); margin-bottom: 6px; display: block; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: 12px 16px;
    font-size: 15px;
    font-family: inherit;
    width: 100%;
    transition: border-color .2s;
    background: #fff;
    color: var(--clr-text, #1a1a2e);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
    outline: none;
    border-color: var(--clr-primary, #054b9e);
}

/* ── Catalog ordering select ─────────────────────────────────── */
.woocommerce-ordering select {
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 14px;
    background: #fff;
    color: var(--clr-text, #1a1a2e);
    font-family: inherit;
    cursor: pointer;
    appearance: none;
    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='%236b7280'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 32px;
}
.woocommerce-ordering select:focus { outline: none; border-color: var(--clr-primary, #054b9e); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1100px) {
    .related-products__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
    .related-products__grid { grid-template-columns: repeat(2, 1fr); }
    .woocommerce ul.products.columns-3 { grid-template-columns: repeat(2, 1fr); }
    .woocommerce ul.products.columns-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .related-products__grid { grid-template-columns: 1fr; }
    .woocommerce ul.products.columns-3,
    .woocommerce ul.products.columns-4 { grid-template-columns: 1fr; }
}

/* ── Lightbox ───────────────────────────────────────────────────────────── */
.apm-lightbox {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: lbIn .18s ease;
}
@keyframes lbIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.apm-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.92);
  cursor: zoom-out;
}
.apm-lightbox__img {
  position: relative;
  z-index: 1;
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 12px 48px rgba(0,0,0,.6);
  animation: lbImgIn .22s cubic-bezier(.22,1,.36,1);
}
@keyframes lbImgIn {
  from { transform: scale(.93); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}
.apm-lightbox__close {
  position: fixed;
  top: 16px; right: 16px;
  z-index: 2;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(6px);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.2);
  cursor: pointer;
  transition: background .2s;
}
.apm-lightbox__close:hover { background: rgba(255,255,255,.28); }
