/* Parent de la colonne de gauche et de droite */
.section-connexion {
    min-height: calc(100vh - var(--header-h));
    display: flex;
    align-items: stretch;
    gap: 32px;
    padding: 64px;
    box-sizing: border-box;
    text-align: center;
}

/* Colonne de gauche */
.contenu-formulaire {
    position: relative;
    background: var(--bleu-logo);
    color: var(--fond-blanc);
    border-radius: 22px;
    padding: 64px 128px;
    box-sizing: border-box;
    flex: 1 1 0;
    min-width: 0;
}

/* Colonne de droite */
.image-formulaire {
    flex: 1 1 0;
    min-width: 0;
    display: flex;

    img {
        border-radius: 22px;
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }
}


/* Textes de la colonne de gauche */
.titre-connexion {
    font-family: var(--titre);
    font-weight: 900;
    font-size: 24px;
    margin-top: 64px;
    margin-bottom: 24px;
}

.texte-connexion {
    font-family: var(--texte);
    font-weight: normal;
    font-size: 18px;
    margin-bottom: 22px;
}

.h3-connexion {
    font-family: var(--texte);
    font-weight: bold;
    font-size: 14px;
    margin-bottom: 64px;
}

.mot-connexion {
    font-family: var(--texte);
    font-weight: 600;
    font-size: 18px;
    margin-bottom: 12px;
    align-self: start;
}

.etoile {
    color: var(--vert-logo);
    font-size: 20px;
}

/* Style du formulaire de la colonne de gauche */
.bouton-connexion {
    font-family: var(--texte);
    font-weight: 900;
    font-size: 18px;
    background: var(--vert-logo);
    color: var(--bleu-logo);
    border-radius: 12px;
    padding: 12px 32px;
    width: fit-content;
    align-self: center;
    border: none;
    cursor: pointer;
}

.bouton-connexion:disabled {
    cursor: not-allowed;
    opacity: 0.75;
}

.bouton-connexion.btn-hover:hover,
.bouton-connexion.btn-hover:active {
    transform: none;
    box-shadow: none;
}

/* Pendant le délai après un mauvais mot de passe */
.connexion-en-attente,
.connexion-en-attente input,
.connexion-en-attente .bouton-connexion {
    cursor: not-allowed;
}

form {
    display: flex;
    flex-direction: column;

    input {
        padding: 14px;
        border-radius: 12px;
        margin-bottom: 32px;
        border: 1px solid var(--vert-logo);
        color: var(--bleu-logo);
        font-family: var(--texte);
        font-weight: bolder;
    }

    input:focus {
        outline-color: var(--vert-logo);
    }

    input::placeholder {
        color: var(--bleu-logo);
        opacity: 0.5;
        font-weight: bolder;
    }
}

/* Champ mot de passe - oeil */
.champ-mdp {
    position: relative;
    width: 100%;
    margin-bottom: 32px;
}

.champ-mdp input {
    width: 100%;
    margin-bottom: 0;
    padding-right: 44px;
    box-sizing: border-box;
}

.toggle-mdp {
    position: absolute;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);
    border: none;
    background: transparent;
    padding: 0;
    cursor: pointer;
    line-height: 0;
}

.toggle-mdp svg {
    width: 24px;
    height: 24px;
}

/* Style des messages d'erreur (mail ou mdp incorrect par exemple) */
.erreur-connexion {
    display: block;
    color: var(--rouge-erreur);
    font-family: var(--texte);
    font-weight: bolder;
    font-size: 15px;
    line-height: 1.4;
    margin: 24px auto 0;
    max-width: 100%;
    width: 100%;
    border-radius: 8px;
    background: var(--fond-blanc);
    padding: 12px 14px;
    box-sizing: border-box;
    overflow-wrap: anywhere;
}

@media (max-width: 900px) {
    .section-connexion {
        flex-direction: column;
        align-items: stretch;
        gap: 20px;
        min-height: calc(100dvh - var(--header-h));
        padding: 24px 16px 32px;
    }

    .contenu-formulaire {
        flex: none;
        width: 100%;
        max-width: 100%;
        padding: 32px 24px 36px;
        border-radius: 16px;
        text-align: left;
    }

    .titre-connexion {
        margin-top: 0;
        margin-bottom: 16px;
        font-size: 22px;
        text-align: center;
    }

    .texte-connexion {
        font-size: 16px;
        margin-bottom: 18px;
        text-align: center;
    }

    .h3-connexion {
        margin-bottom: 28px;
        font-size: 13px;
        text-align: center;
    }

    .mot-connexion {
        font-size: 16px;
        align-self: stretch;
        text-align: left;
    }

    form {
        align-items: stretch;
        width: 100%;
    }

    form input {
        width: 100%;
        box-sizing: border-box;
        margin-bottom: 24px;
        font-size: 16px;
    }

    .champ-mdp {
        margin-bottom: 24px;
    }

    .bouton-connexion {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        font-size: 16px;
    }

    .erreur-connexion {
        margin-top: 20px;
        font-size: 14px;
    }

    .image-formulaire {
        flex: none;
        width: 100%;
        max-width: 100%;
        min-height: 0;
        height: 240px;
        box-sizing: border-box;
    }

    .image-formulaire img {
        border-radius: 16px;
    }
}

@media (max-width: 480px) {
    .section-connexion {
        padding: 20px 12px 28px;
        gap: 16px;
    }

    .contenu-formulaire {
        padding: 24px 16px 28px;
        border-radius: 14px;
    }

    .titre-connexion {
        font-size: 20px;
    }

    .texte-connexion {
        font-size: 15px;
    }

    .h3-connexion {
        margin-bottom: 22px;
    }

    form input {
        padding: 12px;
    }

    .bouton-connexion {
        font-size: 15px;
        padding: 12px 20px;
    }

    .image-formulaire {
        height: 200px;
    }

    .image-formulaire img {
        border-radius: 14px;
    }
}