:root {
    --bg-body: #000000;
    --bg-card: #0f1014;
    --primary: #2563eb;
    --primary-glow: #3b82f6;
    --border-color: #1e293b;
    --text-main: #f8fafc;
    --text-muted: #94a3b8;
    --success: #10b981;
}

body {
    background-color: var(--bg-body);
    color: var(--text-main);
}

body.modal-open .main-layout {
    pointer-events: none;
}

/* --- ANIMAZIONI GLOBALI --- */
@keyframes slideUpFade {
    0% { opacity: 0; transform: translateY(30px) scale(0.98); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes online-pulse {
    0% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.4); background: rgba(74, 222, 128, 0.1); }
    70% { box-shadow: 0 0 0 6px rgba(74, 222, 128, 0); background: rgba(74, 222, 128, 0.2); }
    100% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0); background: rgba(74, 222, 128, 0.1); }
}

@keyframes scale-up { 
    0% { transform: scale(0.5); opacity: 0; } 
    100% { transform: scale(1); opacity: 1; } 
}

@keyframes sponsor-pulse {
    0% { border-color: rgba(255, 215, 0, 0.3); box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3); }
    50% { border-color: rgba(255, 215, 0, 0.8); box-shadow: 0 10px 40px rgba(255, 215, 0, 0.1); }
    100% { border-color: rgba(255, 215, 0, 0.3); box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3); }
}

@keyframes ghost-pulse { 
    0% { opacity: 1; transform: scale(1); } 
    50% { opacity: 0.6; transform: scale(1.1); } 
    100% { opacity: 1; transform: scale(1); } 
}

@keyframes fadeIn { 
    from { opacity: 0; transform: translateY(-5px); } 
    to { opacity: 1; transform: translateY(0); } 
}