/** sections/products.css */
.products { background: var(--ic-bg-mid); }
.products__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr)); gap: var(--ic-space-6); margin-top: var(--ic-space-12); }
.product-card { background: var(--ic-bg-card); border: 1px solid var(--ic-border-dark); border-radius: var(--ic-radius-xl); padding: var(--ic-space-8); display: flex; flex-direction: column; gap: var(--ic-space-5); position: relative; transition: transform var(--ic-duration-base) var(--ic-ease); }
.product-card:hover { transform: translateY(-4px); }
.product-card--featured { border-color: var(--ic-accent); }
.product-card__badge { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); white-space: nowrap; }
.product-card__title { font-family: var(--ic-font-serif); font-size: var(--ic-text-h3); font-weight: 600; }
.product-card__desc { font-size: var(--ic-text-sm); color: var(--ic-text-secondary); line-height: 1.65; flex: 1; }
.product-card__includes { list-style: none; display: flex; flex-direction: column; gap: var(--ic-space-2); }
.product-card__includes li { font-size: var(--ic-text-sm); color: var(--ic-text-secondary); display: flex; align-items: center; gap: var(--ic-space-3); }
.product-card__includes li::before { content: '✓'; color: var(--ic-accent); font-weight: 700; flex-shrink: 0; }
.product-card__price { font-family: var(--ic-font-serif); font-size: var(--ic-text-h2); font-weight: 700; color: var(--ic-text-primary); }
.product-card .btn { margin-top: auto; }

/* Layout: texto izquierda, mockup derecha */
.products__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(var(--ic-space-10), 6vw, var(--ic-space-16));
  align-items: center;
  max-width: 100%;
  margin-top: var(--ic-space-12);
}

.products__text {
  display: flex;
  flex-direction: column;
  gap: var(--ic-space-5);
}

.products__mockup {
  display: flex;
  justify-content: center;
  align-items: center;
}

.products__mockup img {
  max-width: 420px;
  width: 100%;
  filter: drop-shadow(0 32px 64px rgba(0,0,0,0.6));
}

@media (max-width: 767px) {
  .products__grid {
    grid-template-columns: 1fr;
  }
  .products__mockup {
    order: -1;
  }
}
