/**
 * Digital Plus — Product Grid Styles
 * Ported from: shopify-theme/assets/product-grid.css
 * JSX-scoped selectors replaced with .dp-product-grid prefix
 */

/* ===== Grid Page Layout ===== */
.dp-product-list-page {
  padding: 20px 40px 0;
}

.dp-product-page-container {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-xl);
}

/* ===== Filters Sidebar Column ===== */
.dp-filters-form-container {
  flex-basis: 25%;
  flex-shrink: 0;
  transition: flex-basis var(--transition-slow);
}

/* ===== Product List / Pagination Column ===== */
.dp-product-list-pagination-container {
  display: flex;
  flex-direction: column;
  flex-basis: 75%;
  flex: 1;
  margin: 0;
  transition: flex-basis var(--transition-slow);
}

/* ===== Results and Sort Bar ===== */
.dp-results-and-sort-section {
  padding: 0;
}

.dp-results-and-sort-container {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: center;
  gap: var(--spacing-sm);
  min-height: 40px;
  margin-bottom: var(--spacing-md);
}

.dp-results-count {
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
}

.dp-sort-select {
  appearance: none;
  border: 1px solid var(--color-border);
  background: var(--color-background);
  padding: var(--spacing-xs) var(--spacing-md);
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  cursor: pointer;
  outline: none;
  height: 40px;
}

.dp-sort-select:focus {
  border-color: var(--color-accent);
}

/* ===== Product Grid Container ===== */
.dp-product-grid-container {
  background: var(--color-border);
  display: grid;
  gap: 1px;
  grid-template-columns: 1fr;
  padding: 1px;
}

/* 2-column for small screens */
@media (min-width: 374px) {
  .dp-product-grid-container {
    grid-template-columns: 1fr 1fr;
  }
}

/* 2-column with sidebar */
@media (min-width: 1024px) {
  .dp-product-grid-container {
    grid-template-columns: 1fr 1fr;
  }

  .dp-product-list-pagination-container {
    flex: 1;
    margin: 0;
  }

  .dp-no-results-filters {
    margin: 40px 10px 0 0;
    text-align: center;
  }
}

/* 3-column on wide screens */
@media (min-width: 1240px) {
  .dp-product-grid-container {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

/* ===== Product Grid Items ===== */
.dp-product-grid-container > .dp-product-card {
  background: var(--color-background);
  padding: var(--spacing-sm);
}

/* ===== Filters Toggle (Mobile) ===== */
.dp-filters-control {
  display: none;
  padding: 8px 15px;
  border: 1px solid var(--color-border);
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-family: var(--font-body);
  background: var(--color-background);
  transition: all var(--transition-fast);
}

.dp-filters-control:hover {
  background: var(--color-background-alt);
}

/* ===== Featured Products Container ===== */
.dp-featured-products-container {
  padding: 0 40px;
}

/* ===== Gift Products Container ===== */
.dp-gift-products-container {
  padding: 0 40px;
}

/* ===== Trending Products Container ===== */
.dp-trending-products-container {
  background-color: var(--color-background-alt);
  padding: 40px 40px;
}

/* ===== New Arrivals Container ===== */
.dp-new-arrivals-container {
  padding: 0 40px;
}

/* ===== Bento / Featured Grid ===== */
.dp-featured-grid {
  background: var(--color-border);
  border: 1px solid var(--color-border);
  display: grid;
  grid-gap: 1px;
  grid-template-areas:
    "b d a a"
    "c e a a";
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
}

.dp-featured-grid--alt {
  grid-template-areas:
    "a a b d"
    "a a c e";
}

.dp-featured-grid--row {
  grid-template-areas: "a b c d";
  grid-template-rows: repeat(1, minmax(0, 1fr));
}

.dp-featured-grid__item-a { grid-area: a; }
.dp-featured-grid__item-b { grid-area: b; }
.dp-featured-grid__item-c { grid-area: c; }
.dp-featured-grid__item-d { grid-area: d; }
.dp-featured-grid__item-e { grid-area: e; }

/* ===== No Results ===== */
.dp-no-results {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-4xl) var(--spacing-xl);
  text-align: center;
  color: var(--color-text-light);
}

.dp-no-results__icon {
  font-size: 48px;
  margin-bottom: var(--spacing-md);
  opacity: 0.4;
}

.dp-no-results__title {
  font-size: var(--font-size-xl);
  font-family: var(--font-accent);
  font-weight: 300;
  margin-bottom: var(--spacing-sm);
  color: var(--color-text);
}

.dp-no-results__text {
  font-size: var(--font-size-base);
  color: var(--color-text-light);
  max-width: 400px;
}

/* ===== Responsive ===== */
@media (max-width: 1239px) {
  .dp-results-and-sort-container {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dp-results-and-sort-section {
    grid-column: span 2 / span 2;
  }

  .dp-filters-form-container {
    flex-basis: 33.33%;
  }

  .dp-product-list-pagination-container {
    flex-basis: 66.67%;
  }
}

@media (max-width: 1024px) {
  .dp-product-page-container {
    flex-direction: column;
  }

  .dp-filters-form-container {
    display: none;
    width: 100%;
    flex-basis: auto;
  }

  .dp-filters-form-container.open {
    display: block;
  }

  .dp-filters-control {
    display: flex;
  }

  .dp-product-list-pagination-container {
    flex-basis: auto;
    width: 100%;
  }

  .dp-results-and-sort-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-sm);
    min-height: 40px;
  }

  .dp-results-and-sort-container > div {
    border-width: 1px;
  }
}

@media (max-width: 768px) {
  .dp-product-list-page {
    padding: 0 15px;
  }

  .dp-featured-products-container,
  .dp-gift-products-container,
  .dp-new-arrivals-container {
    padding: 0 15px;
  }

  .dp-trending-products-container {
    padding: 15px;
  }

  .dp-featured-grid {
    grid-template-areas:
      "a a"
      "b c";
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
  }
}
