/* joystick.css */
:root {
    --joystick-size: 120px;
    --joystick-stick-size: 50px;
    --joystick-bottom: 50px;
    --joystick-left: 50px;
    --joystick-opacity-idle: 0.3;
    --joystick-opacity-active: 0.8;
}

#virtual-joystick-container {
    position: fixed;
    bottom: var(--joystick-bottom);
    left: var(--joystick-left);
    width: var(--joystick-size);
    height: var(--joystick-size);
    background-color: rgba(255, 255, 255, 0.2);
    border: 2px solid rgba(255, 255, 255, 0.5);
    border-radius: 50%;
    touch-action: none; /* Empêche le scroll natif de la page lors du toucher */
    z-index: 9999;
    opacity: var(--joystick-opacity-idle);
    transition: opacity 0.3s ease;
    display: none; /* Caché par défaut, affiché uniquement sur mobile/tactile si activé */
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(4px);
}

#virtual-joystick-container.active {
    opacity: var(--joystick-opacity-active);
}

#virtual-joystick-stick {
    position: absolute;
    top: 50%;
    left: 50%;
    width: var(--joystick-stick-size);
    height: var(--joystick-stick-size);
    background-color: rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
    pointer-events: none; /* Le container gère les événements */
    transition: transform 0.1s ease-out; /* Pour le retour au centre, temporairement désactivé pendant le drag */
}
