/* ===== HERO SLIDER ===== */
.hero-slider-wrap { padding: 20px 24px 0; max-width: 1160px; margin: 0 auto; }
.hero-slider { position: relative; overflow: hidden; background: #f5f5f5; border-radius: 16px; max-height: 800px; }
.hs-track { display: flex; transition: transform 0.5s cubic-bezier(0.4,0,0.2,1); }
.hs-slide { flex-shrink: 0; width: 100%; line-height: 0; }
.hs-slide img { width: 100%; height: 100%; object-fit: fill; object-position: center; display: block; }
.hs-btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,0.92); color: var(--pink);
  border: none; width: 44px; height: 44px; border-radius: 50%;
  font-size: 1.6rem; font-weight: 700; cursor: pointer; z-index: 10;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px rgba(0,0,0,0.15);
  transition: background var(--transition), transform var(--transition);
}
.hs-btn:hover { background: #fff; transform: translateY(-50%) scale(1.08); }
.hs-prev { left: 14px; } .hs-next { right: 14px; }
.hs-dots { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 10; }
.hs-dot { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,0.5); border: none; cursor: pointer; transition: background var(--transition), transform var(--transition); }
.hs-dot.active { background: var(--pink); transform: scale(1.35); }

/* ===== INTRO ===== */
.intro { padding: 52px 0 30px; text-align: center; }
.intro h1 { font-family: 'Syne', sans-serif; font-size: clamp(1.6rem, 4vw, 2.6rem); font-weight: 800; color: var(--pink); line-height: 1.15; margin-bottom: 14px; }
.intro p { font-size: 1.02rem; color: var(--text-light); max-width: 580px; margin: 0 auto 26px; line-height: 1.7; }
.intro-ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ===== CATEGORY CARDS ===== */
.home-cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.home-cat-card {
  background: var(--card-bg); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 24px 18px; text-align: center; cursor: pointer; text-decoration: none; display: block;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
}
.home-cat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); border-color: var(--pink-muted); }
.home-cat-card img { width: 48px; height: 48px; object-fit: contain; margin: 0 auto 14px; }
.home-cat-card h3 { font-family: 'Syne', sans-serif; font-size: 0.9rem; font-weight: 700; color: var(--text); line-height: 1.3; }
.home-cat-card p { font-size: 0.78rem; color: var(--text-light); margin-top: 6px; }

/* ===== GALLERY SLIDER ===== */
.gallery-outer { position: relative; }
.gallery-wrap { overflow: hidden; border-radius: var(--radius); background: #f5f5f5; }
.gallery-track { display: flex; transition: transform 0.5s cubic-bezier(0.4,0,0.2,1); }
.gallery-slide { flex-shrink: 0; width: calc(100% / 3); padding: 5px; }
.gallery-slide img { width: 100%; height: 220px; object-fit: cover; border-radius: 10px; }
.gallery-btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,0.92); color: var(--pink);
  border: none; width: 38px; height: 38px; border-radius: 50%;
  font-size: 1.3rem; cursor: pointer; z-index: 5;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-sm); transition: box-shadow var(--transition);
}
.gallery-btn:hover { box-shadow: var(--shadow-md); }
.gallery-prev { left: 6px; } .gallery-next { right: 6px; }
.gallery-dots { display: flex; justify-content: center; gap: 7px; margin-top: 14px; }
.gallery-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--pink-muted); border: none; cursor: pointer; transition: background var(--transition), transform var(--transition); }
.gallery-dot.active { background: var(--pink); transform: scale(1.4); }

/* ===== BRANDS ===== */
.brands-strip {
  display: flex; align-items: center; justify-content: center; gap: 36px; flex-wrap: wrap;
  padding: 36px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 12px 0 0;
}
.brands-strip img { height: 38px; width: auto; object-fit: contain; opacity: 0.6; transition: opacity var(--transition); filter: grayscale(0.3); }
.brands-strip img:hover { opacity: 1; }

@media (max-width: 768px) {
  .gallery-slide { width: 50%; }
  .home-cat-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .gallery-slide { width: 100%; }
}
