/* Conteneur du bouton pour alignement */
.custom-button-container {
    display: block;
    margin: 2rem 0;
}

.custom-button-container.text-left {
    text-align: left;
}

.custom-button-container.text-center {
    text-align: center;
}

.custom-button-container.text-right {
    text-align: right;
}

/* Styles de base du bouton avec largeur adaptative */
.custom-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-weight: 500;
    border-radius: 0.375rem;
    transition: all 0.3s ease;
    padding: 0.75rem 1.5rem;
    width: auto; /* Largeur qui s'adapte au contenu */
    max-width: 100%; /* Ne dépasse jamais la largeur de son conteneur */
    border: 2px solid transparent;
    white-space: normal; /* Permettre au texte de passer à la ligne */
    overflow-wrap: break-word; /* Cassera les mots très longs si nécessaire */
    word-wrap: break-word;
}

/* Appliquer un min-width pour que le bouton ne soit pas trop petit */
.custom-button.btn-size-medium {
    min-width: 200px; /* Valeur minimale */
}
/* Mais pour le responsive, permettons le retour à la ligne si l'écran est trop petit */
@media (max-width: 480px) {
    .custom-button {
        white-space: normal; /* Permet au texte de passer à la ligne sur mobile */
    }
}

/* Style noir (comme le bouton "Réserver un essai") */
.custom-button.btn-primary {
    background-color: #000;
    color: #fff !important;
    border-color: #000;
}

.custom-button.btn-primary:hover {
    background-color: #333;
}

/* Style blanc avec bordure (comme le bouton téléphone) */
.custom-button.btn-secondary {
    background-color: #fff;
    color: #000 !important;
    border: 2px solid #000;
}

.custom-button.btn-secondary:hover {
    background-color: #f5f5f5;
}

/* Style violet plein */
.custom-button.btn-violet-filled {
    background-color: #6646ff;
    color: #fff !important;
    border-color: #6646ff;
}

.custom-button.btn-violet-filled:hover {
    background-color: #5535ee;
    border-color: #5535ee;
}

/* Style violet contour */
.custom-button.btn-violet-outline {
    background-color: transparent;
    color: #6646ff !important;
    border: 2px solid #6646ff;
}

.custom-button.btn-violet-outline:hover {
    background-color: #6646ff;
    color: #fff !important;
}

/* Style couleur de marque (sera dynamique) */
.custom-button.btn-brand-color {
    background-color: var(--brand-color, #6646ff);
    color: #fff !important;
    border-color: var(--brand-color, #6646ff);
}

.custom-button.btn-brand-color:hover {
    background-color: var(--brand-color-hover, #5535ee);
    border-color: var(--brand-color-hover, #5535ee);
}

/* Tailles */
.custom-button.btn-size-small {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    min-height: 60px;
    width: 220px;
}

.custom-button.btn-size-medium {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    min-height: 80px;
    width: 280px;
}

.custom-button.btn-size-large {
    padding: 1rem 2rem;
    font-size: 1.125rem;
    min-height: 90px;
}

/* Animation de l'icône */
.custom-button i {
    transition: transform 0.3s ease;
}

.custom-button:hover i {
    transform: translateX(5px);
}

/* Style pour le texte et l'icône */
.button-text {
    flex-grow: 1;
    text-align: center;
}

/* Responsive */
@media (max-width: 768px) {
    .custom-button {
        width: 100%;
    }
}