<div class="slider-demo">
  <div class="slider-container">
    <div class="slider-header">
      <h2>Featured Projects</h2>
      <p>Swipe or use controls to navigate</p>
    </div>
    
    <div class="slider-wrapper">
      <div class="slider-track">
        <div class="slide active">
          <div class="slide-content">
            <div class="slide-image">
              <img src="https://images.unsplash.com/photo-1551650975-87deedd944c3?w=800&h=400&fit=crop" alt="Project 1">
              <div class="slide-overlay">
                <h3>E-commerce Platform</h3>
                <p>Modern shopping experience with React and Node.js</p>
                <div class="slide-tags">
                  <span class="tag">React</span>
                  <span class="tag">Node.js</span>
                  <span class="tag">MongoDB</span>
                </div>
              </div>
            </div>
          </div>
        </div>
        <div class="slide">
          <div class="slide-content">
            <div class="slide-image">
              <img src="https://images.unsplash.com/photo-1461749280684-dccba630e2f6?w=800&h=400&fit=crop" alt="Project 2">
              <div class="slide-overlay">
                <h3>Analytics Dashboard</h3>
                <p>Real-time data visualization with D3.js</p>
                <div class="slide-tags">
                  <span class="tag">D3.js</span>
                  <span class="tag">WebSocket</span>
                  <span class="tag">PostgreSQL</span>
                </div>
              </div>
            </div>
          </div>
        </div>
        <div class="slide">
          <div class="slide-content">
            <div class="slide-image">
              <img src="https://images.unsplash.com/photo-1498050108023-c5249f4df085?w=800&h=400&fit=crop" alt="Project 3">
              <div class="slide-overlay">
                <h3>Mobile App</h3>
                <p>Cross-platform solution with React Native</p>
                <div class="slide-tags">
                  <span class="tag">React Native</span>
                  <span class="tag">Firebase</span>
                  <span class="tag">Redux</span>
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
      
      <button class="slider-btn prev" onclick="slideCarousel(-1)">
        <svg width="24" height="24" viewBox="0 0 24 24" fill="none">
          <path d="M15 18L9 12L15 6" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
        </svg>
      </button>
      
      <button class="slider-btn next" onclick="slideCarousel(1)">
        <svg width="24" height="24" viewBox="0 0 24 24" fill="none">
          <path d="M9 18L15 12L9 6" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
        </svg>
      </button>
    </div>
    
    <div class="slider-dots">
      <span class="dot active" onclick="currentSlide(1)"></span>
      <span class="dot" onclick="currentSlide(2)"></span>
      <span class="dot" onclick="currentSlide(3)"></span>
    </div>
  </div>
</div>
     .slider-demo {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  min-height: 100vh;
  padding: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.slider-container {
  max-width: 800px;
  width: 100%;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 8px 32px rgba(31, 38, 135, 0.37);
  border: 1px solid rgba(255, 255, 255, 0.18);
}
.slider-header {
  text-align: center;
  margin-bottom: 2rem;
  color: white;
}
.slider-header h2 {
  margin: 0 0 0.5rem 0;
  font-size: 2rem;
  font-weight: 600;
}
.slider-header p {
  margin: 0;
  opacity: 0.8;
  font-size: 1rem;
}
.slider-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 15px;
  margin-bottom: 1.5rem;
}
.slider-track {
  display: flex;
  transition: transform 0.5s ease;
  width: 300%;
}
.slide {
  width: 33.333%;
  flex-shrink: 0;
}
.slide-content {
  position: relative;
}
.slide-image {
  position: relative;
  width: 100%;
  height: 300px;
  overflow: hidden;
  border-radius: 15px;
}
.slide-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.slide:hover .slide-image img {
  transform: scale(1.05);
}
.slide-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
  color: white;
  padding: 2rem;
  transform: translateY(20px);
  opacity: 0;
  transition: all 0.3s ease;
}
.slide.active .slide-overlay,
.slide:hover .slide-overlay {
  transform: translateY(0);
  opacity: 1;
}
.slide-overlay h3 {
  margin: 0 0 0.5rem 0;
  font-size: 1.5rem;
  font-weight: 600;
}
.slide-overlay p {
  margin: 0 0 1rem 0;
  opacity: 0.9;
  line-height: 1.4;
}
.slide-tags {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.tag {
  background: rgba(255, 255, 255, 0.2);
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 500;
  backdrop-filter: blur(5px);
}
.slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.2);
  border: none;
  color: white;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  backdrop-filter: blur(5px);
  z-index: 10;
}
.slider-btn:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: translateY(-50%) scale(1.1);
}
.slider-btn.prev {
  left: 1rem;
}
.slider-btn.next {
  right: 1rem;
}
.slider-dots {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
}
.dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  cursor: pointer;
  transition: all 0.3s ease;
}
.dot.active,
.dot:hover {
  background: white;
  transform: scale(1.2);
}
@media (max-width: 768px) {
  .slider-demo {
    padding: 1rem;
  }
  
  .slider-container {
    padding: 1rem;
  }
  
  .slider-header h2 {
    font-size: 1.5rem;
  }
  
  .slide-image {
    height: 200px;
  }
  
  .slider-btn {
    width: 40px;
    height: 40px;
  }
  
  .slider-btn.prev {
    left: 0.5rem;
  }
  
  .slider-btn.next {
    right: 0.5rem;
  }
  
  .slide-overlay {
    padding: 1rem;
  }
  
  .slide-overlay h3 {
    font-size: 1.2rem;
  }
}
     class SliderCarousel {
  constructor() {
    this.currentSlide = 0;
    this.totalSlides = 3;
    this.autoplayInterval = null;
    this.autoplayDelay = 5000;
    this.init();
  }
  init() {
    this.setupEventListeners();
    this.startAutoplay();
    this.setupTouchEvents();
  }
  setupEventListeners() {
    // Pause autoplay on hover
    const container = document.querySelector('.slider-container');
    if (container) {
      container.addEventListener('mouseenter', () => this.stopAutoplay());
      container.addEventListener('mouseleave', () => this.startAutoplay());
    }
  }
  setupTouchEvents() {
    const slider = document.querySelector('.slider-wrapper');
    if (!slider) return;
    let startX = 0;
    let isDragging = false;
    slider.addEventListener('touchstart', (e) => {
      startX = e.touches[0].clientX;
      isDragging = true;
      this.stopAutoplay();
    });
    slider.addEventListener('touchmove', (e) => {
      if (!isDragging) return;
      e.preventDefault();
    });
    slider.addEventListener('touchend', (e) => {
      if (!isDragging) return;
      
      const endX = e.changedTouches[0].clientX;
      const diffX = startX - endX;
      
      if (Math.abs(diffX) > 50) {
        if (diffX > 0) {
          this.nextSlide();
        } else {
          this.prevSlide();
        }
      }
      
      isDragging = false;
      this.startAutoplay();
    });
  }
  updateSlider() {
    const track = document.querySelector('.slider-track');
    const dots = document.querySelectorAll('.dot');
    const slides = document.querySelectorAll('.slide');
    
    if (track) {
      track.style.transform = `translateX(-${this.currentSlide * 33.333}%)`;
    }
    
    // Update dots
    dots.forEach((dot, index) => {
      dot.classList.toggle('active', index === this.currentSlide);
    });
    
    // Update slides
    slides.forEach((slide, index) => {
      slide.classList.toggle('active', index === this.currentSlide);
    });
  }
  nextSlide() {
    this.currentSlide = (this.currentSlide + 1) % this.totalSlides;
    this.updateSlider();
  }
  prevSlide() {
    this.currentSlide = (this.currentSlide - 1 + this.totalSlides) % this.totalSlides;
    this.updateSlider();
  }
  goToSlide(index) {
    this.currentSlide = index;
    this.updateSlider();
  }
  startAutoplay() {
    this.stopAutoplay();
    this.autoplayInterval = setInterval(() => {
      this.nextSlide();
    }, this.autoplayDelay);
  }
  stopAutoplay() {
    if (this.autoplayInterval) {
      clearInterval(this.autoplayInterval);
      this.autoplayInterval = null;
    }
  }
}
// Global functions for button clicks
function slideCarousel(direction) {
  if (window.sliderInstance) {
    if (direction === 1) {
      window.sliderInstance.nextSlide();
    } else {
      window.sliderInstance.prevSlide();
    }
  }
}
function currentSlide(index) {
  if (window.sliderInstance) {
    window.sliderInstance.goToSlide(index - 1);
  }
}
// Initialize when DOM is loaded
document.addEventListener('DOMContentLoaded', function() {
  window.sliderInstance = new SliderCarousel();
});