/* =====================================================
   ATLAS WORKS — FULL SITE RESPONSIVENESS FIX 2026-06-03
   Target: atlasworks.nl (WooCommerce refurbished hardware)
   ===================================================== */

/* ======================
   1. BASE / RESET
   ====================== */

*, *::before, *::after {
  box-sizing: border-box;
}

body {
  overflow-x: hidden !important;
  max-width: 100vw;
}

img {
  max-width: 100%;
  height: auto;
}

/* ======================
   2. LAYOUT WRAPPER
   ====================== */

.wrap,
.woocommerce .woocommerce-notices-wrapper + .woocommerce-products-header + *,
.site-main > .wrap {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  width: 100% !important;
}

/* ======================
   3. BREADCRUMBS
   ====================== */

.aw-pdp-crumbs,
.woocommerce-breadcrumb {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 4px 6px !important;
  font-size: 13px !important;
  color: #5a6878 !important;
  line-height: 1.4 !important;
  padding: 12px 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
}

.aw-pdp-crumbs a,
.woocommerce-breadcrumb a {
  color: #5a6878 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.aw-pdp-crumbs a:hover,
.woocommerce-breadcrumb a:hover {
  color: #1a73e8 !important;
  text-decoration: underline !important;
}

.aw-pdp-crumbs .aw-pdp-crumbs__current,
.woocommerce-breadcrumb > span:last-child {
  font-weight: 600 !important;
  color: #1a1a2e !important;
  max-width: 260px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  display: inline-block !important;
}

.aw-pdp-crumbs .sep,
.woocommerce-breadcrumb .sep {
  color: #b0bec5 !important;
  margin: 0 2px !important;
  flex-shrink: 0 !important;
}

/* ======================
   4. PRODUCT CARDS — ROOT FIX
   ====================== */

ul.products li.product,
.products li.product {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  background: #ffffff !important;
  border-radius: 12px !important;
  border: 1px solid #e8ecf0 !important;
  overflow: hidden !important;
  transition: box-shadow 0.2s ease, transform 0.2s ease !important;
  padding: 0 !important;
  margin: 0 !important;
  position: relative !important;
  /* NO fixed pixel heights */
}

ul.products li.product:hover,
.products li.product:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,0.10) !important;
  transform: translateY(-2px) !important;
}

/* Product image wrapper */
ul.products li.product .woocommerce-loop-product__link,
ul.products li.product a.woocommerce-loop-product__link {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
  text-decoration: none !important;
  color: inherit !important;
  padding: 12px !important;
}

/* Product image — fixed aspect ratio, no distortion */
ul.products li.product .woocommerce-loop-product__link img,
ul.products li.product img.attachment-woocommerce_thumbnail,
ul.products li.product img.wp-post-image {
  aspect-ratio: 4 / 3 !important;
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  background: #f8f9fa !important;
  border-radius: 8px !important;
  display: block !important;
  margin-bottom: 12px !important;
  flex-shrink: 0 !important;
}

/* Product title */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2.woocommerce-loop-product__title {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #1a1a2e !important;
  line-height: 1.4 !important;
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
  /* 2-line clamp */
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}

/* Price */
ul.products li.product .price,
ul.products li.product span.price {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #1a73e8 !important;
  margin: 4px 0 12px 0 !important;
  display: block !important;
  flex-shrink: 0 !important;
}

ul.products li.product .price del,
ul.products li.product span.price del {
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #9aa5b4 !important;
  margin-right: 4px !important;
}

ul.products li.product .price ins,
ul.products li.product span.price ins {
  text-decoration: none !important;
  color: #e53935 !important;
}

/* Add to cart button — pushed to bottom of card */
ul.products li.product .add_to_cart_button,
ul.products li.product .button,
ul.products li.product a.button {
  display: block !important;
  width: calc(100% - 24px) !important;
  margin: auto 12px 12px !important;
  text-align: center !important;
  padding: 10px 16px !important;
  height: 44px !important;
  line-height: 24px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  background: #1a73e8 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  transition: background 0.15s ease !important;
  text-decoration: none !important;
  flex-shrink: 0 !important;
}

ul.products li.product .add_to_cart_button:hover,
ul.products li.product .button:hover,
ul.products li.product a.button:hover {
  background: #1557b0 !important;
}

/* ======================
   5. SHOP CATEGORY GRID
   ====================== */

ul.products.columns-4,
ul.products.columns-3,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
  align-items: stretch !important;
}

ul.products.columns-3 {
  grid-template-columns: repeat(3, 1fr) !important;
}

ul.products.columns-2 {
  grid-template-columns: repeat(2, 1fr) !important;
}

/* ======================
   6. RAIL SECTIONS
   ====================== */

.aw-rail-section {
  width: 100% !important;
  padding: 40px 0 !important;
  overflow: hidden !important;
}

.aw-rail-section__header,
.aw-rail-section > .aw-rail-section__title-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 20px !important;
  padding: 0 24px !important;
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.aw-rail-section__title {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #1a1a2e !important;
  margin: 0 !important;
}

/* Rail nav arrows */
.aw-rail-section__nav {
  display: flex !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}

.aw-rail-section__nav button,
.aw-rail__prev,
.aw-rail__next {
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  border: 1px solid #e8ecf0 !important;
  background: #fff !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.15s, border-color 0.15s !important;
}

.aw-rail-section__nav button:hover,
.aw-rail__prev:hover,
.aw-rail__next:hover {
  background: #f0f4ff !important;
  border-color: #1a73e8 !important;
}

/* ======================
   7. RAILS (horizontal scroll)
   ====================== */

.aw-rail {
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: minmax(220px, 280px) !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  scroll-snap-type: x mandatory !important;
  gap: 16px !important;
  padding: 4px 24px 16px !important;
  max-width: 100% !important;
  /* Styled scrollbar */
  scrollbar-width: thin !important;
  scrollbar-color: #d1d9e0 transparent !important;
}

.aw-rail::-webkit-scrollbar {
  height: 5px !important;
}

.aw-rail::-webkit-scrollbar-track {
  background: transparent !important;
}

.aw-rail::-webkit-scrollbar-thumb {
  background: #d1d9e0 !important;
  border-radius: 999px !important;
}

/* ul.products inside rail — flatten so li.product become direct grid children */
.aw-rail ul.products,
.aw-rail .products {
  display: contents !important;
  grid-template-columns: unset !important;
}

/* Rail cells */
.aw-rail__cell {
  scroll-snap-align: start !important;
  display: flex !important;
  flex-direction: column !important;
  height: auto !important;
  min-width: 0 !important;
  /* Do NOT set fixed height */
}

/* li.product inside rail inherits full height */
.aw-rail li.product,
.aw-rail .aw-rail__cell li.product {
  height: 100% !important;
  scroll-snap-align: start !important;
}

/* ======================
   8. RELATED / UPSELL / CROSS-SELL
   ====================== */

.related.products,
.upsells.products,
.cross-sells {
  padding: 40px 0 !important;
  overflow: hidden !important;
}

.related.products > h2,
.upsells.products > h2,
.cross-sells h2 {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #1a1a2e !important;
  margin-bottom: 20px !important;
  padding: 0 !important;
}

.related.products ul.products,
.upsells.products ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  align-items: stretch !important;
}

/* ======================
   9. GENERAL ALIGNMENT
   ====================== */

/* Only sections that are direct woo shop/archive containers */
.woocommerce-page .aw-rail-section,
.woocommerce-page .related.products,
.woocommerce-page .upsells.products {
  padding: 32px 0 !important;
}

.woocommerce-page .content-area,
.woocommerce-page #primary {
  max-width: 100% !important;
}

/* No BLOCK element wider than viewport — NOT applied to inline/fixed/absolute */
.wrap > *,
main > *,
.site-content > * {
  max-width: 100%;
}

/* Fix WC default list reset */
ul.products {
  list-style: none !important;
  padding-left: 0 !important;
}

/* ======================
   10. DESKTOP (≥ 900px)
   ====================== */

@media (min-width: 900px) {
  .aw-rail {
    grid-auto-columns: minmax(240px, 1fr) !important;
  }

  .woocommerce-page .aw-rail-section,
  .woocommerce-page .related.products,
  .woocommerce-page .upsells.products {
    padding: 48px 0 !important;
  }

  ul.products.columns-4 {
    grid-template-columns: repeat(4, 1fr) !important;
  }

  .related.products ul.products,
  .upsells.products ul.products {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

/* ======================
   11. TABLET (768px — 899px)
   ====================== */

@media (min-width: 768px) and (max-width: 899px) {
  ul.products.columns-4,
  ul.products.columns-3,
  ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .related.products ul.products,
  .upsells.products ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .aw-rail {
    grid-auto-columns: minmax(220px, 260px) !important;
  }

  .wrap {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* ======================
   12. MOBILE (< 768px)
   ====================== */

@media (max-width: 767px) {
  /* 2-column grid on shop pages */
  ul.products.columns-4,
  ul.products.columns-3,
  ul.products.columns-2,
  ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  /* Related/upsell 2 columns on mobile */
  .related.products ul.products,
  .upsells.products ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  /* Rails: ~1.5 cards visible */
  .aw-rail {
    grid-auto-columns: 220px !important;
    padding: 4px 16px 12px !important;
    gap: 12px !important;
    /* Hide scrollbar on mobile */
    scrollbar-width: none !important;
  }

  .aw-rail::-webkit-scrollbar {
    display: none !important;
  }

  /* ATC button larger touch target */
  ul.products li.product .add_to_cart_button,
  ul.products li.product .button,
  ul.products li.product a.button {
    height: 48px !important;
    line-height: 28px !important;
    font-size: 13px !important;
  }

  /* Price larger on mobile */
  ul.products li.product .price,
  ul.products li.product span.price {
    font-size: 18px !important;
  }

  /* Breadcrumbs smaller on mobile */
  .aw-pdp-crumbs,
  .woocommerce-breadcrumb {
    font-size: 12px !important;
  }

  .aw-pdp-crumbs .aw-pdp-crumbs__current,
  .woocommerce-breadcrumb > span:last-child {
    max-width: 160px !important;
  }

  /* Rail section padding on mobile */
  .aw-rail-section {
    padding: 24px 0 !important;
  }

  .aw-rail-section__header,
  .aw-rail-section > .aw-rail-section__title-row {
    padding: 0 16px !important;
  }

  .aw-rail-section__title {
    font-size: 17px !important;
  }

  .wrap {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Single column on very small screens */
}

@media (max-width: 400px) {
  ul.products.columns-4,
  ul.products.columns-3,
  ul.products.columns-2,
  ul.products {
    grid-template-columns: 1fr !important;
  }

  .related.products ul.products,
  .upsells.products ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* ======================
   13. PRODUCT CARD HEIGHT ALIGNMENT FIX
       ("Anderen bekeken ook" / "Waar je gebleven was")
   ====================== */

/* When cards are in a grid, force equal heights */
ul.products,
.aw-rail,
.related.products ul.products,
.upsells.products ul.products {
  align-items: stretch !important;
}

ul.products li.product {
  align-self: stretch !important;
}

/* The link wrapper fills available space */
ul.products li.product .woocommerce-loop-product__link {
  flex: 1 0 auto !important;
}

/* Price + button container stuck to bottom */
ul.products li.product .price {
  margin-top: auto !important;
}

/* ======================
   14. WOOCOMMERCE OVERRIDES
   ====================== */

/* Remove WooCommerce default float layout */
.woocommerce ul.products::after,
.woocommerce ul.products::before {
  display: none !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  clear: none !important;
  width: auto !important;
  margin: 0 !important;
}

/* WC default margin resets */
.woocommerce .products .product,
.woocommerce-page .products .product {
  margin-bottom: 0 !important;
}

/* Remove WC star rating padding issues */
.star-rating {
  margin: 4px 0 8px !important;
  flex-shrink: 0 !important;
}

/* Badge / sale flash */
ul.products li.product .onsale {
  position: absolute !important;
  top: 10px !important;
  left: 10px !important;
  z-index: 2 !important;
  background: #e53935 !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 3px 8px !important;
  border-radius: 4px !important;
  line-height: 1.4 !important;
}

/* ======================
   15. PRINT
   ====================== */

@media print {
  .aw-rail {
    overflow: visible !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    grid-auto-flow: unset !important;
  }

  ul.products li.product:hover {
    box-shadow: none !important;
    transform: none !important;
  }

  .aw-rail-section__nav,
  .aw-rail__prev,
  .aw-rail__next {
    display: none !important;
  }
}
