/* ==========================================================================
   PRODUCTS PAGE STYLES
   Built on top of base.css variables and utilities
   File: assets/css/products.css
   ========================================================================== */

/* Layout for products page */
.products-hero {
  padding-top: var(--space-12);
  padding-bottom: var(--space-12);
}

.products-container {
  display: grid;
  grid-template-columns: 1fr 3fr;
  gap: var(--space-8);
  align-items: start;
}

/* Sidebar filters */
.filters {
  position: sticky;
  top: calc(var(--space-6) + 1rem);
  display: block;
  gap: var(--space-6);
}

.filter-group {
  margin-bottom: var(--space-6);
}

.filter-group h3 {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

.filter-group input[type="search"],
.filter-group input[type="number"],
.filter-group select,
.filter-group .input,
.filter-group .input-sm {
  width: 100%;
  display: block;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-gray-200);
  background: var(--color-white);
  transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.filter-group .price-range {
  display: flex;
  gap: var(--space-3);
  align-items: center;
}

.filter-actions {
  display: flex;
  gap: var(--space-3);
}

/* Toolbar above grid */
.products-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-6);
  gap: var(--space-4);
}

.products-toolbar .results {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.products-toolbar .sort select {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-gray-200);
  background: var(--color-white);
}

/* Product grid specifics */
.products-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.card-product {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

/* Card media */
.card-product .card-media {
  display: block;
  width: 100%;
  overflow: hidden;
  background: linear-gradient(180deg, var(--color-gray-50), var(--color-white));
  border-bottom: 1px solid var(--color-gray-100);
}

.card-product .card-media img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.card-product:hover .card-media img {
  transform: scale(1.03);
}

/* Product meta inside card */
.card-product .card-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5);
  flex: 1 1 auto;
}

.card-product .card-title {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-1);
}

.card-product .card-text {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-3);
  flex: 1 1 auto;
}

/* Price, rating and actions */
.card-product .card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: auto;
}

.card-product .price {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
}

.card-product .rating {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

/* Card actions */
.card-product .card-body .btn {
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-sm);
}

.card-product .card-body .btn + .btn {
  margin-left: var(--space-2);
}

/* Badges (e.g., bestseller/new) */
.card-product .badge {
  position: absolute;
  top: var(--space-4);
  left: var(--space-4);
  z-index: var(--z-index-popover);
  box-shadow: var(--shadow-sm);
}

/* Pagination */
.pagination {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-6);
  align-items: center;
}

.page-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-gray-200);
  background: var(--color-white);
  color: var(--color-text-primary);
  text-decoration: none;
}

.page-link[aria-current="page"],
.page-link.active {
  background: var(--color-primary);
  color: var(--color-text-inverse);
  border-color: var(--color-primary);
}

/* FAQ and CTA */
.products-faq .card-body {
  padding: var(--space-5);
}

.products-cta .card-body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}

/* Small adjustments for forms and labels inside sidebar */
.filter-group label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
  cursor: pointer;
}

/* Accessibility & focus */
.filter-group input:focus,
.filter-group select:focus,
.filter-group .input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px var(--color-primary-subtle);
}

/* Responsive rules */
@media (max-width: 1024px) {
  .products-container {
    grid-template-columns: 1fr;
  }

  .filters {
    position: relative;
    top: 0;
    margin-bottom: var(--space-6);
  }

  .products-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .card-product .card-media img {
    height: 200px;
  }
}

@media (max-width: 640px) {
  .products-grid {
    grid-template-columns: 1fr;
  }

  .card-product .card-media img {
    height: 160px;
  }

  .products-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }

  .products-cta .card-body {
    flex-direction: column;
    gap: var(--space-4);
    align-items: flex-start;
  }
}

/* Small utilities specific to products page */
.btn-add {
  border-radius: var(--radius-full);
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

.sr-results {
  display: inline-block;
  margin-left: var(--space-3);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}
.product-layout {
    display: grid;
    grid-template-columns: 260px 1fr; /* слева фикс, справа остаток */
    gap: 2rem; /* как было */
}

.filters {
    width: 260px; /* подстрахуем */
}
@media (max-width: 1024px) {
    .product-layout {
        grid-template-columns: 1fr; /* одна колонка */
    }

    .filters {
        width: 100%;
        grid-column: 1;
    }

    .products {
        grid-column: 1;
    }
}
@media (max-width: 640px) {
    .product-layout {
        gap: 1.2rem;
    }

    .filters {
        padding: 1rem;
        border: 1px solid #eee;
        border-radius: 8px;
        background: #fff;
    }
}
