/* Fresh, modern homepage skin. Neutral light theme, soft shadows, subtle animations. */
:root {
  --primary: #2563eb;
  --primary-600: #1d4ed8;
  --bg: #f7f8fa;
  --card: #ffffff;
  --ink: #0f172a;
  --muted: #6b7280;
  --ring: rgba(37, 99, 235, 0.15);
  --shadow: 0 6px 24px rgba(15, 23, 42, 0.06);
  --radius: 14px;
}

html, body {
  background: var(--bg);
}

.page-shell {
  max-width: 1200px;
  margin: 0 auto;
  padding: 28px 18px;
}

/* Hero */
.hero-banner {
  position: relative;
  padding: 56px 0 24px;
}
.hero-content {
  background: linear-gradient(135deg, #eef2ff, #f8fafc);
  border: 1px solid #eef2ff;
  border-radius: calc(var(--radius) + 4px);
  padding: 36px 28px;
  box-shadow: var(--shadow);
}
.hero-wave {
  position: absolute;
  inset-inline: 0;
  inset-block-end: -1px;
  width: 100%;
  height: 100px;
  pointer-events: none;
}
.hero-title {
  font-size: clamp(22px, 3.2vw, 36px);
  color: var(--ink);
  margin: 0 0 10px;
}
.hero-sub {
  color: var(--muted);
  margin: 0 0 18px;
}
.hero-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.btn { display: inline-flex; gap: 8px; align-items: center; padding: 10px 16px; border-radius: 10px; border: 1px solid #e5e7eb; background: #fff; color: var(--ink); box-shadow: 0 2px 0 rgba(15,23,42,.04); transition: .2s ease; }
.btn:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(15,23,42,.08); }
.btn-primary { background: var(--primary); color: #fff; border-color: transparent; }
.btn-primary:hover { background: var(--primary-600); }
.btn-ghost { background: transparent; }
.pill { background: #fff; color: var(--primary); border: 1px solid #e5e7eb; font-size: 12px; padding: 2px 8px; border-radius: 999px; margin-inline-start: 8px; }

/* Section head */
.section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.section-title { margin: 0; font-size: 20px; color: var(--ink); }
.link-reset { color: var(--primary); text-decoration: none; font-weight: 600; }
.link-reset:hover { text-decoration: underline; }

/* Categories chips */
.categories-chips { display: flex; gap: 10px; flex-wrap: wrap; padding: 8px 0 14px; }
.chip { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border-radius: 999px; background: #fff; color: var(--ink); border: 1px solid #e5e7eb; box-shadow: 0 1px 0 rgba(15,23,42,.04); transition: .2s; }
.chip i { color: var(--primary); }
.chip:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(15,23,42,.08); }
.chip.is-active { border-color: var(--primary); box-shadow: 0 0 0 4px var(--ring); }

/* Products grid */
.products-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.products-grid--featured { grid-auto-rows: 1fr; }
.product-card { background: var(--card); border: 1px solid #eef2ff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); display: flex; flex-direction: column; }
.payments-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:10px}
.payment-card{background:#fff;border:1px solid #e5eaf0;border-radius:14px;padding:16px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 6px 18px rgba(0,0,0,.04)}
.payment-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.08)}
.product-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.product-info { padding: 14px; display: flex; flex-direction: column; gap: 8px; }
.product-title { font-size: 15px; margin: 0; color: var(--ink); line-height: 1.4; }
.price-line { font-weight: 700; color: var(--ink); display: flex; gap: 10px; align-items: baseline; }
.price-line .old { color: #94a3b8; text-decoration: line-through; font-weight: 500; }
.rating { color: #f59e0b; display: flex; align-items: center; gap: 6px; }
.rating .count { color: var(--muted); font-size: 12px; }
.payment-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f0f5ff;color:#2c5aa0;font-size:22px}
.payment-name{font-weight:800;color:#0f172a}
.payment-note{font-size:13px;color:#475569;text-align:center}
/* Optional visual hint: default expected quality 4/5 */
.rating-hint { display:inline-flex; gap:2px; margin-inline-start:4px; opacity:.7 }
.badge-sale { position: absolute; inset-inline-start: 10px; inset-block-start: 10px; background: #ef4444; color: #fff; padding: 4px 8px; border-radius: 999px; font-size: 12px; z-index: 2; }
.product-card--featured { position: relative; }

/* Empty state */
.empty-state { grid-column: 1 / -1; text-align: center; padding: 48px; color: var(--muted); border: 2px dashed #e5e7eb; border-radius: var(--radius); background: #fff; }
.empty-state i { font-size: 42px; margin-bottom: 10px; color: #cbd5e1; }

/* Utility animations */
.fade-in-up { opacity: 0; transform: translateY(20px); }

/* Small tweaks for header/footer compatibility if present */
header.site-header { background: #fff; box-shadow: var(--shadow); border-bottom: 1px solid #eef2ff; }
footer.site-footer { background: #fff; border-top: 1px solid #eef2ff; }

/* Newsletter CTA */
.newsletter-cta { 
  display: flex; 
  gap: 18px; 
  align-items: center; 
  justify-content: space-between; 
  background: linear-gradient(135deg, #eef2ff, #e0e7ff); 
  border: 1px solid #e0e7ff; 
  border-radius: calc(var(--radius) + 6px); 
  padding: 20px; 
  box-shadow: var(--shadow);
}
.newsletter-cta .copy h3 { margin: 0 0 6px; font-size: 18px; color: var(--ink); }
.newsletter-cta .copy p { margin: 0; color: var(--muted); }
.newsletter-cta .form { 
  display: flex; 
  gap: 10px; 
  width: 100%; 
  max-width: 520px; 
}
.newsletter-cta .form input[type="email"] { 
  flex: 1; 
  padding: 12px 14px; 
  border: 1px solid #dbeafe; 
  border-radius: 10px; 
  background: #fff; 
  outline: none; 
  transition: box-shadow .2s ease, border-color .2s ease; 
}
.newsletter-cta .form input[type="email"]:focus { 
  border-color: var(--primary); 
  box-shadow: 0 0 0 4px var(--ring); 
}

/* Responsive tweaks */

/* Testimonials */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.testimonial-card {
  background: var(--card);
  border: 1px solid #eef2ff;
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.testimonial-card .quote { color: var(--ink); line-height: 1.7; }
.testimonial-card .quote i { color: #94a3b8; margin-inline-start: 6px; }
.testimonial-card .meta { display: flex; align-items: center; gap: 10px; }
.testimonial-card .avatar { width: 36px; height: 36px; border-radius: 50%; background: #e0e7ff; color: var(--primary-600); display: grid; place-items: center; font-weight: 700; }
.testimonial-card .name { font-weight: 700; color: var(--ink); }
.testimonial-card .role { font-size: 12px; color: var(--muted); }

@media (max-width: 900px) {
  .testimonials-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .testimonials-grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .newsletter-cta { flex-direction: column; align-items: stretch; }
  .newsletter-cta .form { max-width: 100%; }
}
/* Products grid tightening on smaller screens */
@media (max-width: 900px){
  .products-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}
@media (max-width: 680px){
  .hero-banner { padding: 32px 0 14px; }
  .hero-content { padding: 22px 16px; }
  .section-title { font-size: 18px; }
  .products-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
  .product-title { font-size: 14px; }
  .product-card img { aspect-ratio: 4/3; }
}
@media (max-width: 420px){
  .products-grid { grid-template-columns: 1fr 1fr; }
}

/* Compact density mode for all products section */
#all-products.compact .products-grid { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; }
#all-products.compact .product-info { padding: 10px; gap: 6px; }
#all-products.compact .product-title { font-size: 14px; }
#all-products.compact .btn { padding: 8px 12px; font-size: 13px; }
