Compare commits

..

No commits in common. "d6fd076fa8aa44a551691d82308b75451a78803a" and "e79957627db29c68c91b28a3151d2272e43ed38d" have entirely different histories.

12 changed files with 323 additions and 451 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 54 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 53 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 18 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 40 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 31 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 35 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 652 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 110 KiB

View File

@ -1,12 +0,0 @@
<?xml version="1.0" encoding="iso-8859-1"?>
<!-- Uploaded to: SVG Repo, www.svgrepo.com, Generator: SVG Repo Mixer Tools -->
<svg height="800px" width="800px" version="1.1" id="Capa_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
viewBox="0 0 60.671 60.671" xml:space="preserve">
<g>
<g>
<ellipse style="fill:#010002;" cx="30.336" cy="12.097" rx="11.997" ry="12.097"/>
<path style="fill:#010002;" d="M35.64,30.079H25.031c-7.021,0-12.714,5.739-12.714,12.821v17.771h36.037V42.9
C48.354,35.818,42.661,30.079,35.64,30.079z"/>
</g>
</g>
</svg>

Before

Width:  |  Height:  |  Size: 594 B

View File

@ -4,7 +4,7 @@
<head> <head>
<meta charset="UTF-8"> <meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Kodepilot</title> <title>Kodepilot Clone</title>
<link rel="stylesheet" href="main.css"> <link rel="stylesheet" href="main.css">
<link rel="stylesheet" href="templateapi/main.css"> <link rel="stylesheet" href="templateapi/main.css">
<link rel="icon" type="image/x-icon" href="assets/images/logo/favicon.ico"> <link rel="icon" type="image/x-icon" href="assets/images/logo/favicon.ico">
@ -479,7 +479,7 @@
</p> </p>
<div class="slide-logo-box"> <div class="slide-logo-box">
<div class="profile-box"> <div class="profile-box">
<img src="assets/images/hai1/user-icon.svg" <img src="https://images.unsplash.com/photo-1542744094-24638eff58bb?w=500&h=400&fit=crop&crop=entropy&cs=tinysrgb"
alt="Client Logo" class="slide-logo"> alt="Client Logo" class="slide-logo">
<div class="profile-info"> <div class="profile-info">
<p class="slide-name">Dhanush</p> <p class="slide-name">Dhanush</p>
@ -500,7 +500,7 @@
</p> </p>
<div class="slide-logo-box"> <div class="slide-logo-box">
<div class="profile-box"> <div class="profile-box">
<img src="assets/images/hai1/user-icon.svg" <img src="https://images.unsplash.com/photo-1542744094-24638eff58bb?w=500&h=400&fit=crop&crop=entropy&cs=tinysrgb"
alt="Client Logo" class="slide-logo"> alt="Client Logo" class="slide-logo">
<div class="profile-info"> <div class="profile-info">
<p class="slide-name">kevin</p> <p class="slide-name">kevin</p>
@ -520,7 +520,7 @@
</p> </p>
<div class="slide-logo-box"> <div class="slide-logo-box">
<div class="profile-box"> <div class="profile-box">
<img src="assets/images/hai1/user-icon.svg" <img src="https://images.unsplash.com/photo-1542744094-24638eff58bb?w=500&h=400&fit=crop&crop=entropy&cs=tinysrgb"
alt="Client Logo" class="slide-logo"> alt="Client Logo" class="slide-logo">
<div class="profile-info"> <div class="profile-info">
<p class="slide-name">John Doe</p> <p class="slide-name">John Doe</p>
@ -548,12 +548,11 @@
<div class="practice-card-icon">💻</div> <div class="practice-card-icon">💻</div>
<h3>Coding Practice</h3> <h3>Coding Practice</h3>
<p>Level up your coding skills by practicing the hiring Questions.</p> <p>Level up your coding skills by practicing the hiring Questions.</p>
<div class="practice-footer-text">400+ Questions</div>
</div> </div>
<a href="#" class="practice-cta-btn">Start Now ➤</a> <a href="#" class="practice-cta-btn">Start Now ➤</a>
</div> </div>
<div class="practice-card-svg"> <div class="practice-card-svg">
<img src="assets/images/codinghiringassesments/nope_1.png" alt="Coding Practice"> <img src="assets/images/mit-ico/ebmpapst.svg" alt="Coding Practice">
</div> </div>
</div> </div>
@ -563,13 +562,13 @@
<div> <div>
<div class="practice-card-icon">📋</div> <div class="practice-card-icon">📋</div>
<h3>Interview Preparation</h3> <h3>Interview Preparation</h3>
<p>Crack Top companies in just 5 days with unbelivable learning</p> <p>Crack Top companies in just 5 days.</p>
<div class="practice-footer-text">20+ Companies</div> <div class="practice-footer-text">20+ Companies</div>
</div> </div>
<a href="#" class="practice-cta-btn">Start Now ➤</a> <a href="#" class="practice-cta-btn">Start Now ➤</a>
</div> </div>
<div class="practice-card-svg"> <div class="practice-card-svg">
<img src="assets/images/codinghiringassesments/nope_2.png" alt="Coding Practice"> <img src="assets/images/mit-ico/ebmpapst.svg" alt="Coding Practice">
</div> </div>
</div> </div>
@ -585,7 +584,7 @@
<a href="#" class="practice-cta-btn">Start Now ➤</a> <a href="#" class="practice-cta-btn">Start Now ➤</a>
</div> </div>
<div class="practice-card-svg"> <div class="practice-card-svg">
<img src="assets/images/codinghiringassesments/nope_3.webp" alt="Coding Practice"> <img src="assets/images/mit-ico/ebmpapst.svg" alt="Coding Practice">
</div> </div>
</div> </div>
@ -601,7 +600,7 @@
<a href="#" class="practice-cta-btn">Start Now ➤</a> <a href="#" class="practice-cta-btn">Start Now ➤</a>
</div> </div>
<div class="practice-card-svg"> <div class="practice-card-svg">
<img src="assets/images/codinghiringassesments/nope_4.webp" alt="Coding Practice"> <img src="assets/images/mit-ico/ebmpapst.svg" alt="Coding Practice">
</div> </div>
</div> </div>
</div> </div>

790
main.css
View File

@ -1105,7 +1105,6 @@
align-items: center; align-items: center;
gap: 20px; gap: 20px;
margin-top: 76px; margin-top: 76px;
padding-bottom: 40px;
} }
.move-slider-box-static { .move-slider-box-static {
@ -1541,440 +1540,355 @@
/*----------------------------------------------------------------------------------------------------------------------*/ /*----------------------------------------------------------------------------------------------------------------------*/
/* Practice Cards Component CSS - Unique class names to prevent conflicts */
/* Practice Cards Component CSS - Unique class names to prevent conflicts */
.practice-cards-container * {
/* Practice Cards Component CSS - Unique class names to prevent conflicts */ margin: 0;
/* Practice Cards Component CSS - Unique class names to prevent conflicts */ padding: 0;
.practice-cards-container * { box-sizing: border-box;
margin: 0; font-family: 'Segoe UI', system-ui, sans-serif;
padding: 0; }
box-sizing: border-box;
font-family: 'Segoe UI', system-ui, sans-serif; .practice-cards-container {
} background-color: #ffffff;
color: #1f2937;
.practice-cards-container { padding: 40px 20px;
background-color: #ffffff; display: flex;
color: #1f2937; flex-direction: column;
padding: 40px 20px; align-items: center;
display: flex; }
flex-direction: column;
align-items: flex-start; .practice-container {
} max-width: 1300px;
width: 100%;
.practice-container { }
max-width: 1200px;
width: 100%; .practice-title {
margin: 0 auto; font-size: 32px;
padding: 0 20px; font-weight: 700;
} margin-bottom: 12px;
color: #111827;
.practice-title { text-align: left;
font-size: 32px; }
font-weight: 700;
margin-bottom: 12px; .practice-subtitle {
color: #111827; font-size: 18px;
text-align: left; color: #6b7280;
width: 100%; max-width: 700px;
} /* margin: 0 auto 40px; */
line-height: 1.5;
.practice-subtitle { text-align: left;
font-size: 18px; }
color: #6b7280;
max-width: 700px; .practice-cards-wrapper {
line-height: 1.5; margin: 30px 0;
text-align: left; display: flex;
width: 100%; height: 380px;
} border-radius: 12px;
overflow: hidden;
.practice-cards-wrapper { /* box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1); */
margin: 30px 0; position: relative;
display: flex; gap: 1px;
height: 380px; background-color: #d1d5db;
border-radius: 12px; padding: 1px;
overflow: hidden; }
position: relative;
gap: 1px; .practice-card {
background-color: #d1d5db; flex: 1;
padding: 1px; display: flex;
width: 100%; transition: all 0.8s cubic-bezier(0.23, 1, 0.32, 1);
} cursor: pointer;
position: relative;
.practice-card { overflow: hidden;
flex: 1; transform-origin: center;
display: flex; background-color: white;
transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1); border-radius: 0;
cursor: pointer; }
position: relative;
overflow: hidden; .practice-card:first-child {
transform-origin: center; border-radius: 11px 0 0 11px;
background-color: white; }
border-radius: 0;
min-width: 80px; .practice-card:last-child {
} border-radius: 0 11px 11px 0;
}
.practice-card:first-child {
border-radius: 11px 0 0 11px; .practice-card-content {
} flex: 1;
padding: 24px;
.practice-card:last-child { display: flex;
border-radius: 0 11px 11px 0; flex-direction: column;
} justify-content: space-between;
transition: all 0.7s ease;
.practice-card-content { min-width: 0;
flex: 1; z-index: 2;
padding: 24px; position: relative;
display: flex; }
flex-direction: column;
justify-content: space-between; /* Color changes for active and hover states */
transition: all 0.5s ease; .practice-card.active {
min-width: 280px; background-color: #c6e0f1;
z-index: 2; }
position: relative;
} .practice-card:nth-child(1):hover,
.practice-card:nth-child(1).active {
/* Default state - first card expanded */ background-color: #89CFF0;
.practice-card:first-child { }
flex: 2.5;
z-index: 10; .practice-card:nth-child(2):hover,
} .practice-card:nth-child(2).active {
background-color: #FEB4CF;
.practice-card:not(:first-child) { }
flex: 1;
} .practice-card:nth-child(3):hover,
.practice-card:nth-child(3).active {
.practice-card .practice-card-svg { background-color: #DFC5FE;
width: 0; }
opacity: 0;
} .practice-card:nth-child(4):hover,
.practice-card:nth-child(4).active {
.practice-card .practice-cta-btn { background-color: #FFE186;
opacity: 0; }
transform: translateY(15px);
} /* SVG Container */
.practice-card-svg {
/* Show SVG and CTA for first card by default */ width: 0;
.practice-card:first-child .practice-card-svg { height: 100%;
width: 35%; display: flex;
opacity: 1; align-items: center;
} justify-content: center;
transition: all 1.3s cubic-bezier(0.23, 1, 0.32, 1);
.practice-card:first-child .practice-cta-btn { opacity: 0;
opacity: 1; padding: 20px;
transform: translateY(0); background: transparent;
} }
.practice-card:first-child .practice-card-icon { .practice-card-svg svg {
transform: scale(1.05) rotate(3deg); width: 100%;
} height: 100%;
max-width: 180px;
.practice-card:first-child h3 { max-height: 180px;
transform: translateY(-2px); filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.1));
} }
.practice-card:first-child p, .practice-card-icon {
.practice-card:first-child .practice-meta-info, width: 48px;
.practice-card:first-child .practice-footer-text { height: 48px;
transform: translateY(-1px); border-radius: 10px;
} display: flex;
align-items: center;
/* Hover state - expand hovered card, shrink others */ justify-content: center;
.practice-cards-wrapper .practice-card { font-size: 24px;
transform: scale(1); margin-bottom: 16px;
} transition: transform 0.5s ease;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
.practice-cards-wrapper .practice-card:hover { }
flex: 2.5;
z-index: 10; .practice-card:nth-child(1) .practice-card-icon {
} background-color: #1268f3;
color: white;
.practice-cards-wrapper .practice-card:not(:hover) { }
flex: 1;
} .practice-card:nth-child(2) .practice-card-icon {
background-color: #ef4444;
/* Color changes for hover states */ color: white;
.practice-card:nth-child(1):hover { }
background-color: #89CFF0;
} .practice-card:nth-child(3) .practice-card-icon {
background-color: #8b5cf6;
.practice-card:nth-child(2):hover { color: white;
background-color: #FEB4CF; }
}
.practice-card:nth-child(4) .practice-card-icon {
.practice-card:nth-child(3):hover { background-color: #f59e0b;
background-color: #DFC5FE; color: white;
} }
.practice-card:nth-child(4):hover { .practice-card h3 {
background-color: #FFE186; font-size: 20px;
} font-weight: 600;
margin-bottom: 12px;
/* SVG Container - UPDATED FOR IMAGES */ color: #111827;
.practice-card-svg { transition: transform 0.5s ease;
width: 0; }
height: 100%;
display: flex; .practice-card p {
align-items: center; font-size: 15px;
justify-content: center; color: #6b7280;
transition: all 0.8s cubic-bezier(0.23, 1, 0.32, 1); line-height: 1.5;
opacity: 0; margin-bottom: 16px;
padding: 20px; transition: transform 0.5s ease;
background: transparent; }
flex-shrink: 0;
overflow: hidden; /* Added to contain the image */ .practice-meta-info {
} display: flex;
align-items: center;
/* Image styling - NEW RULES */ margin-bottom: 16px;
.practice-card-svg img { font-size: 14px;
width: 500%; color: #4b5563;
height:1200%; transition: transform 0.5s ease;
object-fit: contain; /* This will scale the image properly */ }
max-width: 200%;
max-height: 200%; .practice-meta-logo {
border-radius: 8px; width: 24px;
} height: 24px;
background-color: #3b82f6;
/* Show SVG only on hovered card and first card by default */ border-radius: 4px;
.practice-card:hover .practice-card-svg { margin-right: 8px;
width: 35%; display: flex;
opacity: 1; align-items: center;
} justify-content: center;
color: white;
.practice-card-icon { font-size: 12px;
width: 48px; font-weight: bold;
height: 48px; }
border-radius: 10px;
display: flex; .practice-footer-text {
align-items: center; font-size: 14px;
justify-content: center; font-weight: 600;
font-size: 24px; color: #374151;
margin-bottom: 16px; margin-top: auto;
transition: transform 0.5s ease; transition: transform 0.5s ease;
} }
.practice-card:nth-child(1) .practice-card-icon { .practice-cta-btn {
background-color: #1268f3; margin-top: 16px;
color: white; background-color: #111827;
} color: white;
padding: 10px 16px;
.practice-card:nth-child(2) .practice-card-icon { border-radius: 8px;
background-color: #ef4444; font-size: 14px;
color: white; font-weight: 600;
} text-decoration: none;
width: fit-content;
.practice-card:nth-child(3) .practice-card-icon { display: inline-flex;
background-color: #8b5cf6; align-items: center;
color: white; gap: 6px;
} transition: all 0.7s cubic-bezier(0.23, 1, 0.32, 1);
opacity: 0;
.practice-card:nth-child(4) .practice-card-icon { transform: translateY(15px);
background-color: #f59e0b; position: relative;
color: white; overflow: hidden;
} box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
/* Icon animation on hover */
.practice-card:hover .practice-card-icon { .practice-cta-btn::before {
transform: scale(1.05) rotate(3deg); content: '';
} position: absolute;
top: 0;
.practice-card h3 { left: -100%;
font-size: 20px; width: 100%;
font-weight: 600; height: 100%;
margin-bottom: 12px; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
color: #111827; transition: left 0.8s;
transition: transform 0.5s ease; }
}
.practice-cta-btn:hover::before {
.practice-card p { left: 100%;
font-size: 15px; }
color: #6b7280;
line-height: 1.5; .practice-cta-btn:hover {
margin-bottom: 16px; background-color: #374151;
transition: transform 0.5s ease; transform: translateY(-2px);
} box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15);
}
.practice-meta-info {
display: flex; /* Active card styles */
align-items: center; .practice-card.active {
margin-bottom: 16px; flex: 3.5;
font-size: 14px; transform: translateY(-8px) scale(1.02);
color: #4b5563; box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15);
transition: transform 0.5s ease; z-index: 10;
} }
.practice-meta-logo { .practice-card.active .practice-card-svg {
width: 24px; width: 45%;
height: 24px; opacity: 1;
background-color: #3b82f6; }
border-radius: 4px;
margin-right: 8px; .practice-card.active .practice-cta-btn {
display: flex; opacity: 1;
align-items: center; transform: translateY(0);
justify-content: center; }
color: white;
font-size: 12px; .practice-card.active .practice-card-icon {
font-weight: bold; transform: scale(1.1) rotate(5deg);
} }
.practice-footer-text { .practice-card.active h3 {
font-size: 14px; transform: translateY(-3px);
font-weight: 600; }
color: #374151;
margin-top: auto; .practice-card.active p,
transition: transform 0.5s ease; .practice-card.active .practice-meta-info,
} .practice-card.active .practice-footer-text {
transform: translateY(-2px);
/* Text animation on hover */ }
.practice-card:hover h3 {
transform: translateY(-2px); /* Hover effects for non-active cards */
} .practice-card:hover:not(.active) {
flex: 1.3;
.practice-card:hover p, transform: translateY(-4px) scale(1.01);
.practice-card:hover .practice-meta-info, box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
.practice-card:hover .practice-footer-text { z-index: 5;
transform: translateY(-1px); }
}
.practice-card:hover:not(.active) .practice-card-svg {
.practice-cta-btn { width: 25%;
margin-top: 16px; opacity: 0.8;
background-color: #111827; }
color: white;
padding: 10px 16px; /* Subtle overlay effect */
border-radius: 8px; .practice-card::after {
font-size: 14px; content: '';
font-weight: 600; position: absolute;
text-decoration: none; top: 0;
width: fit-content; left: 0;
display: inline-flex; width: 100%;
align-items: center; height: 100%;
gap: 6px; background: linear-gradient(to bottom, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 100%);
transition: all 0.7s cubic-bezier(0.23, 1, 0.32, 1); opacity: 0;
opacity: 0; transition: opacity 0.6s ease;
transform: translateY(15px); pointer-events: none;
position: relative; }
overflow: hidden;
} .practice-card.active::after,
.practice-card:hover::after {
.practice-cta-btn::before { opacity: 1;
content: ''; }
position: absolute;
top: 0; @media (max-width: 992px) {
left: -100%; .practice-cards-wrapper {
width: 100%; flex-direction: column;
height: 100%; height: auto;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent); border-radius: 12px;
transition: left 0.8s; }
}
.practice-card {
.practice-cta-btn:hover::before { flex-direction: column;
left: 100%; height: auto;
} border-radius: 0 !important;
}
.practice-cta-btn:hover {
background-color: #374151; .practice-card:first-child {
transform: translateY(-2px); border-radius: 12px 12px 0 0 !important;
} }
/* Show CTA button only on hovered card and first card by default */ .practice-card:last-child {
.practice-card:hover .practice-cta-btn { border-radius: 0 0 12px 12px !important;
opacity: 1; }
transform: translateY(0);
} .practice-card.active .practice-card-svg,
.practice-card:hover .practice-card-svg {
/* Subtle overlay effect */ width: 100%;
.practice-card::after { height: 200px;
content: ''; }
position: absolute;
top: 0; .practice-card.active {
left: 0; transform: translateY(-5px) scale(1.01);
width: 100%; }
height: 100%;
background: linear-gradient(to bottom, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 100%); .practice-card:hover:not(.active) {
opacity: 0; transform: translateY(-3px) scale(1.005);
transition: opacity 0.6s ease; }
pointer-events: none; }
}
.practice-card:hover::after {
opacity: 1;
}
/* Mobile responsiveness */
@media (max-width: 992px) {
.practice-cards-container {
align-items: flex-start;
padding: 30px 15px;
}
.practice-cards-wrapper {
flex-direction: column;
height: auto;
border-radius: 12px;
gap: 0;
}
.practice-card {
flex-direction: row;
height: 120px;
border-radius: 0 !important;
min-width: auto;
}
.practice-card:first-child {
border-radius: 12px 12px 0 0 !important;
height: 120px;
flex: 1;
}
.practice-card:last-child {
border-radius: 0 0 12px 12px !important;
}
.practice-card:hover {
height: 300px;
flex-direction: column;
}
.practice-card:hover .practice-card-svg {
width: 100%;
height: 120px;
}
/* Mobile image styling */
.practice-card:hover .practice-card-svg img {
object-fit: cover; /* Better fit for mobile */
}
.practice-card-content {
min-width: auto;
padding: 20px;
}
}
@media (max-width: 768px) {
.practice-cards-container {
padding: 25px 10px;
}
.practice-title {
font-size: 28px;
}
.practice-subtitle {
font-size: 16px;
}
}
@media (max-width: 480px) {
.practice-cards-container {
padding: 20px 8px;
}
.practice-title {
font-size: 24px;
}
.practice-subtitle {
font-size: 14px;
}
}

45
main.js
View File

@ -502,45 +502,16 @@ function stepScroll() {
setInterval(stepScroll, 3000); setInterval(stepScroll, 3000);
document.querySelectorAll('.course-slider').forEach(slider => {
const track = slider.querySelector('.course-track');
const prev = slider.querySelector('.prev-btn');
const next = slider.querySelector('.next-btn');
/*--------------------------------------------------------*/ prev.addEventListener('click', () => {
track.scrollBy({ left: -300, behavior: 'smooth' });
document.addEventListener('DOMContentLoaded', function() {
const cards = document.querySelectorAll('.practice-card');
let activeCard = document.querySelector('.practice-card.active');
let lastActiveCard = activeCard;
// Function to set active card
function setActiveCard(card) {
// Remove active class from all cards
cards.forEach(c => {
c.classList.remove('active');
});
// Add active class to the specified card
card.classList.add('active');
// Update last active card
lastActiveCard = card;
}
// Set first card as active by default if none is active
if (!activeCard && cards.length > 0) {
setActiveCard(cards[0]);
}
// Add click event listeners (better for mobile and accessibility)
cards.forEach(card => {
card.addEventListener('click', function() {
setActiveCard(this);
});
}); });
// Optional: Add hover effect for desktop (complementary to click) next.addEventListener('click', () => {
cards.forEach(card => { track.scrollBy({ left: 300, behavior: 'smooth' });
card.addEventListener('mouseenter', function() {
// Only activate on hover if you want that behavior
// setActiveCard(this);
});
}); });
}); });