/* Shop Sofas page-specific styles */

.hero-section {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background: linear-gradient(108deg,#edeef1 50%,#f7f8fa 100%);
  border-radius: var(--radius-lg);
  margin-top: var(--space-8);
  margin-bottom: var(--space-8);
  padding-top: var(--space-12);
  padding-bottom: var(--space-12);
}
.hero-content {
  max-width: 540px;
}
.sofa-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-8);
  margin-top: var(--space-6);
}
.sofa-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: box-shadow 0.15s;
}
.sofa-card:hover {
  box-shadow: var(--shadow-md);
}
.sofa-card img {
  border-radius: var(--radius-md);
}
.sofa-title {
  font-weight: 600;
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-2);
  margin-top: 0;
}
.sofa-brief {
  font-size: var(--font-size-sm);
  color: var(--color-neutral-600);
  margin-bottom: var(--space-2);
}
.sofa-price {
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}
.sofa-card .button {
  align-self: flex-start;
  margin-top: auto;
}

.customization-options-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px,1fr));
  gap: var(--space-8);
  margin-top: var(--space-4);
}
.customization-option {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-xs);
  text-align: center;
}
.customization-option img {
  margin-bottom: var(--space-3);
  border-radius: var(--radius-md);
}
.quality-list {
  list-style: disc;
  padding-left: var(--space-8);
  color: var(--color-neutral-700);
}
.quality-list li {
  margin-bottom: var(--space-2);
  font-size: var(--font-size-md);
}

.reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-6);
  margin-top: var(--space-4);
}
.review-card {
  background: #fff;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
  padding: var(--space-4);
  font-style: italic;
  min-height: 160px;
}
.review-card footer {
  margin-top: var(--space-2);
  font-size: var(--font-size-sm);
  font-style: normal;
  color: var(--color-primary);
}
.room-planner-section,
.promotions-section,
.guides-section,
.support-section {
  margin-bottom: var(--space-8);
}
.promotion-list {
  list-style: disc;
  padding-left: var(--space-8);
}
.promotion-list li {
  margin-bottom: var(--space-2);
}
.newsletter-signup {
  margin-top: var(--space-3);
  background: #fff;
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
}
.newsletter-signup label {
  font-weight: 500;
}
.signup-row {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.newsletter-signup input[type="email"] {
  max-width: 260px;
}
.guide-list {
  list-style: disc;
  padding-left: var(--space-8);
}
.guide-list li {
  margin-bottom: var(--space-2);
}
.support-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-4);
}
.button.secondary {
  background: var(--color-neutral-200);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
}
.button.secondary:hover, .button.secondary:focus-visible {
  background: var(--color-neutral-300);
}
@media (max-width: 700px) {
  .hero-content,
  .sofa-card,
  .customization-option,
  .newslette-signup {
    padding-left: var(--space-2);
    padding-right: var(--space-2);
  }
  .signup-row {
    flex-direction: column;
    gap: var(--space-2);
  }
  .support-actions {
    flex-direction: column;
    gap: var(--space-3);
  }
}
