Spaces:
Running
Running
| <html lang="en"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>Pranit Chilbule - AI/ML Engineer & MERN Developer</title> | |
| <link href="https://fonts.googleapis.com/css2?family=Roboto+Mono:wght@400;500;700&family=Inter:wght@300;400;500;600&display=swap" rel="stylesheet"> | |
| <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css"> | |
| <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/three.min.js"></script> | |
| <style> | |
| * { | |
| margin: 0; | |
| padding: 0; | |
| box-sizing: border-box; | |
| } | |
| :root { | |
| --bg-primary: #0d1117; | |
| --bg-secondary: #010409; | |
| --text-primary: #c9d1d9; | |
| --text-secondary: rgba(201, 209, 217, 0.8); | |
| --accent-blue: #58a6ff; | |
| --accent-green: #10a37f; | |
| --header-bg: rgba(0, 0, 0, 0.6); | |
| --border-color: rgba(201, 209, 217, 0.1); | |
| } | |
| body { | |
| background-color: var(--bg-primary); | |
| color: var(--text-primary); | |
| font-family: 'Inter', sans-serif; | |
| line-height: 1.6; | |
| overflow-x: hidden; | |
| } | |
| /* Three.js Canvas */ | |
| #three-canvas { | |
| position: fixed; | |
| top: 0; | |
| left: 0; | |
| width: 100%; | |
| height: 100%; | |
| z-index: -1; | |
| pointer-events: none; | |
| } | |
| /* Header */ | |
| header { | |
| position: fixed; | |
| top: 0; | |
| left: 0; | |
| width: 100%; | |
| padding: 1rem 2rem; | |
| background: var(--header-bg); | |
| backdrop-filter: blur(10px); | |
| z-index: 1000; | |
| transition: all 0.3s ease; | |
| } | |
| nav { | |
| display: flex; | |
| justify-content: space-between; | |
| align-items: center; | |
| max-width: 1200px; | |
| margin: 0 auto; | |
| } | |
| .logo { | |
| font-family: 'Roboto Mono', monospace; | |
| font-size: 1.5rem; | |
| font-weight: 700; | |
| color: var(--text-primary); | |
| text-decoration: none; | |
| transition: color 0.3s ease; | |
| } | |
| .logo:hover { | |
| color: var(--accent-blue); | |
| } | |
| .nav-links { | |
| display: flex; | |
| list-style: none; | |
| gap: 2rem; | |
| } | |
| .nav-links a { | |
| color: var(--text-primary); | |
| text-decoration: none; | |
| font-weight: 500; | |
| transition: color 0.3s ease; | |
| position: relative; | |
| } | |
| .nav-links a:hover { | |
| color: var(--accent-blue); | |
| } | |
| .nav-links a::after { | |
| content: ''; | |
| position: absolute; | |
| bottom: -5px; | |
| left: 0; | |
| width: 0; | |
| height: 2px; | |
| background: var(--accent-blue); | |
| transition: width 0.3s ease; | |
| } | |
| .nav-links a:hover::after { | |
| width: 100%; | |
| } | |
| /* Main Hero Section */ | |
| main { | |
| min-height: 100vh; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| padding: 0 2rem; | |
| position: relative; | |
| } | |
| .hero-content { | |
| text-align: center; | |
| max-width: 1200px; | |
| width: 100%; | |
| margin: 0 auto; | |
| padding-top: 80px; /* Added to account for fixed header */ | |
| animation: fadeInUp 1s ease-out; | |
| } | |
| @keyframes fadeInUp { | |
| from { | |
| opacity: 0; | |
| transform: translateY(30px); | |
| } | |
| to { | |
| opacity: 1; | |
| transform: translateY(0); | |
| } | |
| } | |
| .hero-content h1 { | |
| font-family: 'Roboto Mono', monospace; | |
| font-size: 4rem; | |
| font-weight: 700; | |
| white-space: nowrap; /* Keeps name in one line */ | |
| margin-left: 0; /* Removed left margin */ | |
| background: linear-gradient(135deg, var(--accent-blue), var(--accent-green)); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| background-clip: text; | |
| animation: glow 2s ease-in-out infinite alternate; | |
| } | |
| @keyframes glow { | |
| from { | |
| text-shadow: 0 0 20px rgba(88, 166, 255, 0.5); | |
| } | |
| to { | |
| text-shadow: 0 0 30px rgba(88, 166, 255, 0.8); | |
| } | |
| } | |
| .hero-content p { | |
| font-size: 1.25rem; | |
| letter-spacing: 1px; | |
| opacity: 0.8; | |
| margin-bottom: 2.5rem; | |
| font-weight: 300; | |
| } | |
| .cta-buttons { | |
| display: flex; | |
| gap: 1rem; | |
| justify-content: center; | |
| flex-wrap: wrap; | |
| } | |
| .btn { | |
| padding: 0.75rem 1.5rem; | |
| border: none; | |
| border-radius: 50px; | |
| font-size: 1rem; | |
| font-weight: 500; | |
| text-decoration: none; | |
| cursor: pointer; | |
| transition: all 0.3s ease; | |
| display: inline-block; | |
| } | |
| .btn-primary { | |
| background: var(--accent-blue); | |
| color: white; | |
| } | |
| .btn-primary:hover { | |
| box-shadow: 0 0 20px rgba(88, 166, 255, 0.6); | |
| transform: translateY(-2px); | |
| } | |
| .btn-secondary { | |
| background: transparent; | |
| color: var(--accent-green); | |
| border: 2px solid var(--accent-green); | |
| } | |
| .btn-secondary:hover { | |
| background: var(--accent-green); | |
| color: white; | |
| box-shadow: 0 0 20px rgba(16, 163, 127, 0.4); | |
| transform: translateY(-2px); | |
| } | |
| /* About Section */ | |
| #about { | |
| padding: 4rem 2rem; | |
| background: rgba(13, 17, 23, 0.8); | |
| backdrop-filter: blur(10px); | |
| border-radius: 15px; | |
| border: 1px solid var(--border-color); | |
| margin: 2rem auto; | |
| max-width: 1200px; | |
| } | |
| .about-grid { | |
| display: grid; | |
| grid-template-columns: 1fr 2fr; | |
| gap: 4rem; | |
| align-items: center; | |
| } | |
| .profile-image { | |
| display: flex; | |
| justify-content: center; | |
| align-items: center; | |
| } | |
| .profile-image img { | |
| width: 200px; | |
| height: 200px; | |
| border-radius: 50%; | |
| border: 4px solid var(--accent-blue); | |
| box-shadow: 0 10px 30px rgba(88, 166, 255, 0.3); | |
| transition: transform 0.3s ease; | |
| } | |
| .profile-image img:hover { | |
| transform: scale(1.05); | |
| } | |
| .about-content { | |
| max-width: 600px; | |
| } | |
| .about-content h2 { | |
| font-size: 2.5rem; | |
| margin-bottom: 1rem; | |
| position: relative; | |
| display: inline-block; | |
| } | |
| .about-content h2::after { | |
| content: ''; | |
| position: absolute; | |
| width: 100%; | |
| height: 2px; | |
| bottom: -5px; | |
| left: 0; | |
| background: var(--accent-blue); | |
| transform: scaleX(0); | |
| transition: transform 0.3s ease; | |
| } | |
| .about-content h2:hover::after { | |
| transform: scaleX(1); | |
| } | |
| .quick-info { | |
| display: flex; | |
| gap: 2rem; | |
| margin: 2rem 0; | |
| } | |
| .info-item { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.5rem; | |
| } | |
| .info-icon { | |
| font-size: 1.5rem; | |
| } | |
| /* Journey Sliders */ | |
| .journey-sliders { | |
| padding: 4rem 2rem; | |
| overflow: hidden; | |
| background: rgba(13, 17, 23, 0.8); | |
| backdrop-filter: blur(10px); | |
| border-radius: 15px; | |
| border: 1px solid var(--border-color); | |
| margin: 2rem auto; | |
| max-width: 1400px; | |
| } | |
| .section-title { | |
| text-align: center; | |
| font-size: 2.5rem; | |
| margin-bottom: 2rem; | |
| color: var(--text-primary); | |
| background: linear-gradient(135deg, var(--accent-blue), var(--accent-green)); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| background-clip: text; | |
| } | |
| .slider-container { | |
| position: relative; | |
| padding: 2rem 0; | |
| margin-bottom: 2rem; | |
| } | |
| .slider-track { | |
| display: flex; | |
| width: calc(250px * 18); | |
| animation: scroll 40s linear infinite; | |
| } | |
| .slider-track.reverse { | |
| animation-direction: reverse; | |
| } | |
| .slider-item { | |
| width: 250px; | |
| height: 180px; | |
| padding: 0 15px; | |
| flex-shrink: 0; | |
| } | |
| .slider-item img { | |
| width: 100%; | |
| height: 100%; | |
| object-fit: cover; | |
| border-radius: 10px; | |
| border: 2px solid var(--accent-blue); | |
| transition: transform 0.3s ease, box-shadow 0.3s ease; | |
| } | |
| .slider-item img:hover { | |
| transform: scale(1.05); | |
| box-shadow: 0 0 20px rgba(88, 166, 255, 0.3); | |
| } | |
| @keyframes scroll { | |
| 0% { | |
| transform: translateX(0); | |
| } | |
| 100% { | |
| transform: translateX(calc(-250px * 9)); | |
| } | |
| } | |
| .slider-container::before, | |
| .slider-container::after { | |
| content: ''; | |
| position: absolute; | |
| top: 0; | |
| width: 200px; | |
| height: 100%; | |
| z-index: 2; | |
| } | |
| .slider-container::before { | |
| left: 0; | |
| background: linear-gradient(to right, var(--bg-primary), transparent); | |
| } | |
| .slider-container::after { | |
| right: 0; | |
| background: linear-gradient(to left, var(--bg-primary), transparent); | |
| } | |
| /* Footer */ | |
| footer { | |
| position: fixed; | |
| bottom: 0; | |
| left: 0; | |
| width: 100%; | |
| padding: 1rem 2rem; | |
| background: var(--bg-secondary); | |
| z-index: 100; | |
| } | |
| .footer-content { | |
| display: flex; | |
| justify-content: center; | |
| align-items: center; | |
| max-width: 1200px; | |
| margin: 0 auto; | |
| gap: 0.5rem; | |
| } | |
| .social-icon { | |
| width: 24px; | |
| height: 24px; | |
| fill: var(--text-secondary); | |
| transition: fill 0.3s ease; | |
| cursor: pointer; | |
| } | |
| .social-icon:hover { | |
| fill: var(--accent-green); | |
| } | |
| /* Mobile Menu Toggle */ | |
| .menu-toggle { | |
| display: none; | |
| flex-direction: column; | |
| cursor: pointer; | |
| gap: 4px; | |
| } | |
| .menu-toggle span { | |
| width: 25px; | |
| height: 3px; | |
| background: var(--text-primary); | |
| transition: all 0.3s ease; | |
| } | |
| /* Update the header styles */ | |
| .header-profile-img { | |
| width: 50px; | |
| height: 50px; | |
| border-radius: 50%; | |
| margin-left: 1rem; | |
| border: 2px solid var(--accent-blue); | |
| object-fit: cover; | |
| } | |
| .logo-container { | |
| display: flex; | |
| align-items: center; | |
| gap: 1rem; | |
| } | |
| .header-profile-img { | |
| width: 40px; | |
| height: 40px; | |
| border-radius: 50%; | |
| border: 2px solid var(--accent-blue); | |
| object-fit: cover; | |
| transition: transform 0.3s ease, box-shadow 0.3s ease; | |
| } | |
| .header-profile-img:hover { | |
| transform: scale(1.1); | |
| box-shadow: 0 0 15px rgba(88, 166, 255, 0.4); | |
| } | |
| /* Add to your existing styles */ | |
| .profile-container { | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; /* Changed to center */ | |
| margin-bottom: 2rem; | |
| padding: 0 2rem; | |
| gap: 6rem; | |
| width: 100%; /* Added to ensure full width */ | |
| } | |
| .profile-wrapper { | |
| position: relative; | |
| width: 300px; /* Increased width */ | |
| height: 300px; /* Increased height */ | |
| border-radius: 10px; /* Changed from 50% to 10px for slight rounding */ | |
| overflow: hidden; | |
| border: 3px solid var(--accent-blue); | |
| box-shadow: 0 0 20px rgba(88, 166, 255, 0.3); | |
| animation: float 6s ease-in-out infinite; | |
| background: var(--bg-primary); | |
| } | |
| .profile-img { | |
| width: 450px; /* Increased size */ | |
| height: 450px; /* Increased size */ | |
| object-fit: contain; | |
| transform: scale(1); | |
| transition: all 0.3s ease; | |
| border: 4px solid var(--accent-blue); /* Added bright border */ | |
| box-shadow: 0 0 30px rgba(88, 166, 255, 0.5); /* Added glow effect */ | |
| border-radius: 15px; /* Optional: slight rounded corners */ | |
| padding: 10px; | |
| background: rgba(13, 17, 23, 0.8); /* Semi-transparent background */ | |
| } | |
| .profile-img:hover { | |
| transform: scale(1.02); | |
| border-color: var(--accent-green); /* Color change on hover */ | |
| box-shadow: 0 0 40px rgba(16, 163, 127, 0.6); /* Enhanced glow on hover */ | |
| } | |
| .ai-overlay { | |
| position: absolute; | |
| top: 0; | |
| left: 0; | |
| width: 100%; | |
| height: 100%; | |
| pointer-events: none; | |
| } | |
| .scanning-line { | |
| position: absolute; | |
| width: 100%; | |
| height: 2px; | |
| background: linear-gradient(90deg, transparent, var(--accent-blue), transparent); | |
| animation: scan 2s linear infinite; | |
| } | |
| .ai-particles { | |
| position: absolute; | |
| width: 100%; | |
| height: 100%; | |
| background: radial-gradient(circle at center, transparent 30%, rgba(88, 166, 255, 0.1)); | |
| animation: pulse 2s ease-in-out infinite; | |
| } | |
| @keyframes scan { | |
| 0% { | |
| top: 0; | |
| opacity: 0; | |
| } | |
| 50% { | |
| opacity: 1; | |
| } | |
| 100% { | |
| top: 100%; | |
| opacity: 0; | |
| } | |
| } | |
| @keyframes pulse { | |
| 0%, 100% { | |
| transform: scale(1); | |
| opacity: 0.5; | |
| } | |
| 50% { | |
| transform: scale(1.1); | |
| opacity: 0.8; | |
| } | |
| } | |
| @keyframes float { | |
| 0%, 100% { | |
| transform: translateY(0); | |
| } | |
| 50% { | |
| transform: translateY(-10px); | |
| } | |
| } | |
| /* Responsive Design */ | |
| @media (max-width: 1200px) { | |
| .hero-content h1 { | |
| font-size: 3.5rem; | |
| } | |
| .profile-container { | |
| gap: 4rem; | |
| } | |
| .hero-content h1 { | |
| margin-left: 1rem; | |
| } | |
| } | |
| @media (max-width: 768px) { | |
| header { | |
| padding: 1rem; | |
| } | |
| .nav-links { | |
| display: none; | |
| position: absolute; | |
| top: 100%; | |
| left: 0; | |
| width: 100%; | |
| background: var(--header-bg); | |
| backdrop-filter: blur(10px); | |
| flex-direction: column; | |
| padding: 1rem 0; | |
| gap: 1rem; | |
| } | |
| .nav-links.active { | |
| display: flex; | |
| } | |
| .menu-toggle { | |
| display: flex; | |
| } | |
| .hero-content h1 { | |
| font-size: 2.5rem; | |
| } | |
| .hero-content p { | |
| font-size: 1.1rem; | |
| } | |
| .cta-buttons { | |
| flex-direction: column; | |
| align-items: center; | |
| } | |
| .btn { | |
| width: 200px; | |
| } | |
| .about-grid { | |
| grid-template-columns: 1fr; | |
| } | |
| .journey-sliders { | |
| padding: 2rem 1rem; | |
| } | |
| .section-title { | |
| font-size: 2rem; | |
| } | |
| .slider-item { | |
| width: 200px; | |
| height: 150px; | |
| } | |
| .logo-container { | |
| gap: 0.5rem; | |
| } | |
| .header-profile-img { | |
| width: 32px; | |
| height: 32px; | |
| } | |
| .profile-container { | |
| flex-direction: column; | |
| text-align: center; | |
| gap: 2rem; | |
| } | |
| .hero-content h1 { | |
| margin-left: 0; | |
| } | |
| } | |
| @media (max-width: 480px) { | |
| main { | |
| padding: 0 1rem; | |
| } | |
| .hero-content h1 { | |
| font-size: 2rem; | |
| } | |
| .hero-content p { | |
| font-size: 1rem; | |
| letter-spacing: 0.5px; | |
| } | |
| header { | |
| padding: 0.75rem 1rem; | |
| } | |
| footer { | |
| padding: 0.75rem 1rem; | |
| } | |
| } | |
| /* Smooth scroll behavior */ | |
| html { | |
| scroll-behavior: smooth; | |
| } | |
| /* Loading animation */ | |
| .loading { | |
| opacity: 0; | |
| animation: fadeIn 0.5s ease-in forwards; | |
| } | |
| @keyframes fadeIn { | |
| to { | |
| opacity: 1; | |
| } | |
| } | |
| /* AI Particles */ | |
| .ai-particles { | |
| position: fixed; | |
| top: 0; | |
| left: 0; | |
| width: 100%; | |
| height: 100%; | |
| pointer-events: none; | |
| overflow: hidden; | |
| z-index: 0; | |
| } | |
| .ai-particle { | |
| position: absolute; | |
| width: 4px; | |
| height: 4px; | |
| background: var(--accent-blue); | |
| border-radius: 50%; | |
| pointer-events: none; | |
| } | |
| @keyframes particleFloat { | |
| 0% { | |
| transform: translateY(0); | |
| } | |
| 50% { | |
| transform: translateY(-10px); | |
| } | |
| 100% { | |
| transform: translateY(0); | |
| } | |
| } | |
| </style> | |
| </head> | |
| <body> | |
| <!-- Three.js Canvas --> | |
| <canvas id="three-canvas"></canvas> | |
| <!-- Header --> | |
| <header> | |
| <nav> | |
| <div class="logo-container"> | |
| <a href="index.html" class="logo">Pranit Chilbule</a> | |
| <img src="images/0_rOIc88HfNzBtAhru.gif" alt="Profile" class="header-profile-img"> | |
| </div> | |
| <div class="menu-toggle" onclick="toggleMenu()"> | |
| <span></span> | |
| <span></span> | |
| <span></span> | |
| </div> | |
| <ul class="nav-links" id="navLinks"> | |
| <li><a href="index.html" class="nav-home"><i class="fas fa-house"></i> Home</a></li> | |
| <li><a href="about.html" class="nav-about"><i class="fas fa-user"></i> About</a></li> | |
| <li><a href="projects.html" class="nav-projects"><i class="fas fa-code"></i> Projects</a></li> | |
| <li><a href="achievements.html" class="nav-achievements"><i class="fas fa-trophy"></i> Achievements</a></li> | |
| <li><a href="contact.html" class="nav-contact"><i class="fas fa-envelope"></i> Contact</a></li> | |
| </ul> | |
| </nav> | |
| </header> | |
| <!-- Main Hero Section --> | |
| <main id="home"> | |
| <div class="hero-content loading"> | |
| <div class="profile-container"> | |
| <h1>Pranit Chilbule</h1> | |
| <img src="images/0_rOIc88HfNzBtAhru.gif" alt="Profile" class="profile-img"> | |
| </div> | |
| <p>AI/ML Engineer | MERN Developer | Tech Enthusiast</p> | |
| <div class="cta-buttons"> | |
| <a href="#about" class="btn btn-primary">Learn More</a> | |
| <a href="projects.html" class="btn btn-secondary">View Projects</a> | |
| </div> | |
| </div> | |
| </main> | |
| <!-- Journey Sliders Section --> | |
| <section class="journey-sliders fade-in"> | |
| <h2 class="section-title">My Journey</h2> | |
| <!-- First Slider - Moving Left --> | |
| <div class="slider-container"> | |
| <div class="slider-track"> | |
| <!-- First set of images --> | |
| <div class="slider-item"><img src="images/1 (1).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (2).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (3).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (4).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (5).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (6).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (7).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (8).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (9).jpg" alt="Journey moment"></div> | |
| <!-- Duplicate for seamless loop --> | |
| <div class="slider-item"><img src="images/1 (1).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (2).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (3).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (4).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (5).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (6).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (7).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (8).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (9).jpg" alt="Journey moment"></div> | |
| </div> | |
| </div> | |
| <!-- Second Slider - Moving Right --> | |
| <div class="slider-container"> | |
| <div class="slider-track reverse"> | |
| <!-- Second set of images --> | |
| <div class="slider-item"><img src="images/1 (10).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (11).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (12).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (13).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (14).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (15).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (16).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (17).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (18).jpg" alt="Journey moment"></div> | |
| <!-- Duplicate for seamless loop --> | |
| <div class="slider-item"><img src="images/1 (10).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (11).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (12).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (13).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (14).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (15).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (16).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (17).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (18).jpg" alt="Journey moment"></div> | |
| </div> | |
| </div> | |
| <!-- Third Slider - Moving Left --> | |
| <div class="slider-container"> | |
| <div class="slider-track"> | |
| <!-- Third set of images --> | |
| <div class="slider-item"><img src="images/1 (19).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (20).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (21).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (22).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (23).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (24).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (25).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (26).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (27).jpg" alt="Journey moment"></div> | |
| <!-- Duplicate for seamless loop --> | |
| <div class="slider-item"><img src="images/1 (19).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (20).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (21).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (22).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (23).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (24).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (25).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (26).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (27).jpg" alt="Journey moment"></div> | |
| </div> | |
| </div> | |
| <!-- Fourth Slider - Moving Right --> | |
| <div class="slider-container"> | |
| <div class="slider-track reverse"> | |
| <!-- Fourth set of images --> | |
| <div class="slider-item"><img src="images/1 (28).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (29).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (30).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (31).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (32).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (33).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (34).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (35).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (36).jpg" alt="Journey moment"></div> | |
| <!-- Duplicate for seamless loop --> | |
| <div class="slider-item"><img src="images/1 (28).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (29).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (30).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (31).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (32).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (33).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (34).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (35).jpg" alt="Journey moment"></div> | |
| <div class="slider-item"><img src="images/1 (36).jpg" alt="Journey moment"></div> | |
| </div> | |
| </div> | |
| </section> | |
| <!-- About Section --> | |
| <section id="about" class="fade-in"> | |
| <div class="about-grid"> | |
| <div class="profile-image"> | |
| <img src="images/121415604.jpeg" alt="Pranit Chilbule Profile Picture"> | |
| </div> | |
| <div class="about-content"> | |
| <h2>About Me</h2> | |
| <p> | |
| I'm a 3rd-year AI/ML engineering student at VIT Pune, passionate about building intelligent systems that solve real-world problems. My journey in technology spans from developing cutting-edge machine learning models to creating robust web applications using the MERN stack. | |
| </p> | |
| <div class="quick-info"> | |
| <div class="info-item"> | |
| <span class="info-icon">🎓</span> | |
| <span>AI/ML Engineer</span> | |
| </div> | |
| <div class="info-item"> | |
| <span class="info-icon">💻</span> | |
| <span>MERN Developer</span> | |
| </div> | |
| <div class="info-item"> | |
| <span class="info-icon">🚀</span> | |
| <span>Tech Enthusiast</span> | |
| </div> | |
| </div> | |
| <div class="cta-buttons"> | |
| <a href="about.html" class="btn btn-primary">Full Bio</a> | |
| <a href="#contact" class="btn btn-secondary">Get in Touch</a> | |
| </div> | |
| </div> | |
| </div> | |
| </section> | |
| <!-- Footer --> | |
| <footer> | |
| <div class="footer-content"> | |
| <a href="www.linkedin.com/in/pranit-chilbule-03ba7b1b5" target="_blank"> | |
| <svg class="social-icon" viewBox="0 0 24 24"> | |
| <path d="M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433c-1.144 0-2.063-.926-2.063-2.065 0-1.138.92-2.063 2.063-2.063 1.14 0 2.064.925 2.064 2.063 0 1.139-.925 2.065-2.064 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.222 0h.003z"/> | |
| </svg> | |
| </a> | |
| <a href="https://github.com/pranit144" target="_blank"> | |
| <svg class="social-icon" viewBox="0 0 24 24"> | |
| <path d="M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z"/> | |
| </svg> | |
| </a> | |
| <a href="/blog.html" target="_blank"> | |
| <svg class="social-icon" viewBox="0 0 24 24"> | |
| <path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"/> | |
| </svg> | |
| </a> | |
| </div> | |
| </footer> | |
| <script> | |
| // Three.js Particle Network Background | |
| let scene, camera, renderer, particles, lines; | |
| let particleCount = 100; | |
| let mouseX = 0, mouseY = 0; | |
| let windowHalfX = window.innerWidth / 2; | |
| let windowHalfY = window.innerHeight / 2; | |
| function initThreeJS() { | |
| const canvas = document.getElementById('three-canvas'); | |
| // Scene setup | |
| scene = new THREE.Scene(); | |
| camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000); | |
| renderer = new THREE.WebGLRenderer({ canvas: canvas, alpha: true }); | |
| renderer.setSize(window.innerWidth, window.innerHeight); | |
| renderer.setClearColor(0x000000, 0); | |
| // Create particles | |
| const geometry = new THREE.BufferGeometry(); | |
| const positions = new Float32Array(particleCount * 3); | |
| const velocities = []; | |
| for (let i = 0; i < particleCount; i++) { | |
| positions[i * 3] = (Math.random() - 0.5) * 2000; | |
| positions[i * 3 + 1] = (Math.random() - 0.5) * 2000; | |
| positions[i * 3 + 2] = (Math.random() - 0.5) * 2000; | |
| velocities.push({ | |
| x: (Math.random() - 0.5) * 2, | |
| y: (Math.random() - 0.5) * 2, | |
| z: (Math.random() - 0.5) * 2 | |
| }); | |
| } | |
| geometry.setAttribute('position', new THREE.BufferAttribute(positions, 3)); | |
| const material = new THREE.PointsMaterial({ | |
| color: 0x58a6ff, | |
| size: 2, | |
| transparent: true, | |
| opacity: 0.8 | |
| }); | |
| particles = new THREE.Points(geometry, material); | |
| particles.userData = { velocities: velocities }; | |
| scene.add(particles); | |
| // Create lines | |
| const lineGeometry = new THREE.BufferGeometry(); | |
| const lineMaterial = new THREE.LineBasicMaterial({ | |
| color: 0x58a6ff, | |
| transparent: true, | |
| opacity: 0.3 | |
| }); | |
| lines = new THREE.LineSegments(lineGeometry, lineMaterial); | |
| scene.add(lines); | |
| camera.position.z = 1000; | |
| // Start animation | |
| animate(); | |
| } | |
| function animate() { | |
| requestAnimationFrame(animate); | |
| // Update particles positions | |
| const positions = particles.geometry.attributes.position.array; | |
| const velocities = particles.userData.velocities; | |
| for (let i = 0; i < particleCount; i++) { | |
| positions[i * 3] += velocities[i].x; | |
| positions[i * 3 + 1] += velocities[i].y; | |
| positions[i * 3 + 2] += velocities[i].z; | |
| // Boundary check | |
| if (positions[i * 3] > 1000 || positions[i * 3] < -1000) velocities[i].x *= -1; | |
| if (positions[i * 3 + 1] > 1000 || positions[i * 3 + 1] < -1000) velocities[i].y *= -1; | |
| if (positions[i * 3 + 2] > 1000 || positions[i * 3 + 2] < -1000) velocities[i].z *= -1; | |
| } | |
| particles.geometry.attributes.position.needsUpdate = true; | |
| // Update lines between close particles | |
| updateLines(); | |
| // Camera movement based on mouse | |
| camera.position.x += (mouseX - camera.position.x) * 0.05; | |
| camera.position.y += (-mouseY - camera.position.y) * 0.05; | |
| camera.lookAt(scene.position); | |
| renderer.render(scene, camera); | |
| } | |
| function updateLines() { | |
| const positions = particles.geometry.attributes.position.array; | |
| const linePositions = []; | |
| for (let i = 0; i < particleCount; i++) { | |
| for (let j = i + 1; j < particleCount; j++) { | |
| const dx = positions[i * 3] - positions[j * 3]; | |
| const dy = positions[i * 3 + 1] - positions[j * 3 + 1]; | |
| const dz = positions[i * 3 + 2] - positions[j * 3 + 2]; | |
| const distance = Math.sqrt(dx * dx + dy * dy + dz * dz); | |
| if (distance < 120) {.style.display = 'block'; | |
| linePositions.push(positions[i * 3], positions[i * 3 + 1], positions[i * 3 + 2]); | |
| linePositions.push(positions[j * 3], positions[j * 3 + 1], positions[j * 3 + 2]); | |
| } | |
| } | |
| } | |
| nks = document.getElementById('navLinks'); | |
| lines.geometry.setAttribute('position', new THREE.Float32BufferAttribute(linePositions, 3));nks.classList.toggle('active'); | |
| } | |
| // Mouse movement tracking // Smooth scroll for internal links | |
| document.addEventListener('mousemove', (event) => {]').forEach(anchor => { | |
| mouseX = event.clientX - windowHalfX;nction (e) { | |
| mouseY = event.clientY - windowHalfY;efault(); | |
| }); const target = document.querySelector(this.getAttribute('href')); | |
| // Window resize handlerollIntoView({ | |
| window.addEventListener('resize', () => { | |
| windowHalfX = window.innerWidth / 2; block: 'start' | |
| windowHalfY = window.innerHeight / 2; }); | |
| } | |
| camera.aspect = window.innerWidth / window.innerHeight; | |
| camera.updateProjectionMatrix(); | |
| renderer.setSize(window.innerWidth, window.innerHeight); | |
| ge loads | |
| // Pause animation on mobile | |
| if (window.innerWidth < 600) {eJS(); | |
| renderer.domElement.style.display = 'none'; | |
| anchor.addEventListener('click', function (e) {/ Show content with animation | |
| e.preventDefault(); setTimeout(() => { | |
| const target = document.querySelector(this.getAttribute('href')); document.querySelector('.hero-content').classList.remove('loading'); | |
| if (target) { }, 100); | |
| target.scrollIntoView({ }); |