.glass-demo {
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
padding: 2rem;
}
.glass-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 2rem;
max-width: 1200px;
width: 100%;
}
.glass-card {
position: relative;
background: rgba(255, 255, 255, 0.1);
backdrop-filter: blur(15px);
border: 1px solid rgba(255, 255, 255, 0.2);
border-radius: 24px;
padding: 2.5rem;
transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
cursor: pointer;
overflow: hidden;
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}
.glass-card:hover {
transform: translateY(-12px) scale(1.02);
background: rgba(255, 255, 255, 0.15);
box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15);
border-color: rgba(255, 255, 255, 0.3);
}
.glass-content {
position: relative;
z-index: 2;
text-align: center;
}
.glass-icon {
font-size: 3rem;
margin-bottom: 1.5rem;
display: block;
filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.2));
}
.glass-card h3 {
color: white;
font-size: 1.5rem;
font-weight: 700;
margin-bottom: 1rem;
text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}
.glass-card p {
color: rgba(255, 255, 255, 0.9);
font-size: 1rem;
line-height: 1.6;
margin-bottom: 2rem;
text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.glass-stats {
display: flex;
justify-content: space-between;
gap: 1rem;
}
.glass-stats span {
background: rgba(255, 255, 255, 0.15);
color: white;
padding: 0.5rem 1rem;
border-radius: 20px;
font-size: 0.85rem;
font-weight: 600;
backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.2);
flex: 1;
text-align: center;
text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.glass-shine {
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(
90deg,
transparent,
rgba(255, 255, 255, 0.2),
transparent
);
transition: left 0.6s ease;
z-index: 1;
}
.glass-card:hover .glass-shine {
left: 100%;
}
@media (max-width: 768px) {
.glass-demo {
padding: 1rem;
}
.glass-grid {
grid-template-columns: 1fr;
gap: 1.5rem;
}
.glass-card {
padding: 2rem;
}
.glass-icon {
font-size: 2.5rem;
margin-bottom: 1rem;
}
.glass-card h3 {
font-size: 1.3rem;
}
.glass-card p {
font-size: 0.9rem;
margin-bottom: 1.5rem;
}
.glass-stats {
flex-direction: column;
gap: 0.75rem;
}
}
class GlassCardEffect {
constructor() {
this.cards = document.querySelectorAll('.glass-card');
this.init();
}
init() {
this.cards.forEach(card => {
this.addTiltEffect(card);
this.addMouseTracker(card);
});
}
addTiltEffect(card) {
card.addEventListener('mousemove', (e) => {
const rect = card.getBoundingClientRect();
const x = e.clientX - rect.left;
const y = e.clientY - rect.top;
const centerX = rect.width / 2;
const centerY = rect.height / 2;
const rotateX = (y - centerY) / 10;
const rotateY = (centerX - x) / 10;
card.style.transform = `perspective(1000px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) translateY(-12px) scale(1.02)`;
});
card.addEventListener('mouseleave', () => {
card.style.transform = 'perspective(1000px) rotateX(0deg) rotateY(0deg) translateY(0px) scale(1)';
});
}
addMouseTracker(card) {
card.addEventListener('mousemove', (e) => {
const rect = card.getBoundingClientRect();
const x = e.clientX - rect.left;
const y = e.clientY - rect.top;
// Crear efecto de seguimiento del mouse
const mouseTracker = card.querySelector('.mouse-tracker') || this.createMouseTracker(card);
mouseTracker.style.left = `${x}px`;
mouseTracker.style.top = `${y}px`;
mouseTracker.style.opacity = '1';
});
card.addEventListener('mouseleave', () => {
const mouseTracker = card.querySelector('.mouse-tracker');
if (mouseTracker) {
mouseTracker.style.opacity = '0';
}
});
}
createMouseTracker(card) {
const tracker = document.createElement('div');
tracker.className = 'mouse-tracker';
tracker.style.cssText = `
position: absolute;
width: 100px;
height: 100px;
background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
border-radius: 50%;
pointer-events: none;
transform: translate(-50%, -50%);
transition: opacity 0.3s ease;
opacity: 0;
z-index: 1;
`;
card.appendChild(tracker);
return tracker;
}
}
// Inicializar cuando el DOM esté listo
document.addEventListener('DOMContentLoaded', () => {
new GlassCardEffect();
});
// Agregar efectos de partículas de fondo
class BackgroundParticles {
constructor() {
this.canvas = this.createCanvas();
this.ctx = this.canvas.getContext('2d');
this.particles = [];
this.init();
this.animate();
}
createCanvas() {
const canvas = document.createElement('canvas');
canvas.style.cssText = `
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
pointer-events: none;
z-index: -1;
opacity: 0.3;
`;
document.body.appendChild(canvas);
this.resizeCanvas(canvas);
window.addEventListener('resize', () => this.resizeCanvas(canvas));
return canvas;
}
resizeCanvas(canvas) {
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
}
init() {
const particleCount = Math.min(50, Math.floor(window.innerWidth * window.innerHeight / 15000));
for (let i = 0; i < particleCount; i++) {
this.particles.push({
x: Math.random() * this.canvas.width,
y: Math.random() * this.canvas.height,
vx: (Math.random() - 0.5) * 0.5,
vy: (Math.random() - 0.5) * 0.5,
size: Math.random() * 2 + 1,
alpha: Math.random() * 0.5 + 0.2
});
}
}
animate() {
this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height);
this.particles.forEach(particle => {
particle.x += particle.vx;
particle.y += particle.vy;
if (particle.x < 0 || particle.x > this.canvas.width) particle.vx *= -1;
if (particle.y < 0 || particle.y > this.canvas.height) particle.vy *= -1;
this.ctx.beginPath();
this.ctx.arc(particle.x, particle.y, particle.size, 0, Math.PI * 2);
this.ctx.fillStyle = `rgba(255, 255, 255, ${particle.alpha})`;
this.ctx.fill();
});
requestAnimationFrame(() => this.animate());
}
}
// Inicializar partículas de fondo
document.addEventListener('DOMContentLoaded', () => {
new BackgroundParticles();
});