/* Parent du formulaire de contact */
.contenu-formulaire {
    min-height: 90vh;
    padding: 32px 200px;
    display: flex;
    flex-direction: column;
    background-image:
        url("../images/rouage_gris.png"),
        url("../images/rouage_gris.png");
    background-repeat: no-repeat, no-repeat;
    background-size: 500px, 600px;
    background-position: 75% 150%, 120% 170%;

    .titre-contact {
        font-family: var(--titre);
        color: var(--bleu-logo);
        font-size: 24px;
        font-weight: 900;
    }

    p {
        font-family: var(--texte);
        font-size: 18px;
        font-weight: 500;
    }
}

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

/* Messages retour envoi (même logique que « Nous rejoindre ») */
.candidature-feedback {
    font-family: var(--texte);
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 24px;
    padding: 14px 18px;
    border-radius: 8px;
}

.candidature-feedback--ok {
    color: var(--bleu-logo);
    background: color-mix(in srgb, var(--vert-logo) 22%, transparent);
    border: 1px solid var(--vert-logo);
}

.candidature-feedback--erreur {
    color: var(--rouge-erreur);
    background: color-mix(in srgb, var(--rouge-erreur) 12%, transparent);
    border: 1px solid var(--rouge-erreur);
}

.form-validation-summary[hidden] {
    display: none;
}

.field-error {
    display: block;
    min-height: 1.35em;
    margin: 0;
    padding-top: 4px;
    font-family: var(--texte);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
    color: var(--rouge-erreur);
    overflow-wrap: anywhere;
}

.form-group--invalid input,
.form-group--invalid textarea,
.form-group--invalid select {
    border-bottom-color: var(--rouge-erreur);
    outline: 2px solid color-mix(in srgb, var(--rouge-erreur) 28%, transparent);
    outline-offset: 0;
}

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

.label-formulaire {
    font-family: var(--titre);
    color: var(--bleu-logo);
    font-size: 18px;
    font-weight: 900;
}

.form-candidature {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: 24px;
    row-gap: 16px;
}

.form-candidature .full {
    grid-column: 1 / -1;
}

.form-candidature .form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
}

.form-candidature input,
.form-candidature select {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    border: none;
    border-bottom: solid 2px var(--vert-logo);
    background: var(--gris);
    padding: 12px;
    font-family: var(--texte);
    font-weight: bolder;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

textarea {
    resize: vertical;
    min-height: 110px;
    max-height: 220px;
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    border: none;
    border-bottom: solid 2px var(--vert-logo);
    background: var(--gris);
    padding: 12px;
    font-family: var(--texte);
    font-weight: bolder;
}

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

textarea::placeholder {
    opacity: 0.5;
}

.bouton-candidature {
    font-family: var(--texte);
    font-weight: 900;
    font-size: 18px;
    background: var(--vert-logo);
    color: var(--bleu-logo);
    padding: 12px 32px;
    border-radius: 12px;
    width: fit-content;
    align-self: center;
    border: none;
    cursor: pointer;
}

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

input::placeholder {
    opacity: 0.5;
}



/* Partie en dessous du formulaire infos + carte */

.contenu-info {
    display: flex;
    justify-content: space-evenly;
    text-align: center;
    margin-top: 56px;
}

/* Colonne de gauche */
.colonne-texte {
    background: var(--bleu);
    color: var(--fond-blanc);
    padding: 64px 128px;
    box-sizing: border-box;
    width: 100%;
}

/* Colonne de droite */
.colonne-map {
    width: 100%;
}


/* Textes de la colonne de gauche */
.titre-info {
    font-family: var(--titre);
    font-weight: 900;
    font-size: 24px;
    margin-bottom: 24px;
    /* color: var(--bleu-logo); */
}

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


.gras-vert, .lien {
    font-weight: 600;
    color: var(--vert-logo);
}

.colonne-map iframe {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    min-height: 280px;
    aspect-ratio: 1100 / 480;
    border: 0;
}

.texte-info .lien {
    overflow-wrap: anywhere;
}

/* PC : colonne infos plus étroite, carte plus large, sans bande blanche sous la map */
@media (min-width: 901px) {
    .contenu-info {
        align-items: stretch;
        justify-content: flex-start;
    }

    .colonne-texte {
        flex: 0 0 46%;
        max-width: none;
        width: auto;
        padding: 52px 64px;
    }

    .colonne-map {
        flex: 1 1 54%;
        width: auto;
        min-width: 0;
        max-width: 54%;
        display: flex;
    }

    .colonne-map iframe {
        flex: 1 1 auto;
        width: 100%;
        height: 100%;
        min-height: 360px;
        aspect-ratio: unset;
    }
}

@media (max-width: 900px) {
    .contenu-formulaire {
        min-height: auto;
        padding: 32px 24px 40px;
        background-size: 320px, 380px;
        background-position: 105% 85%, 112% 105%;
    }

    .contenu-formulaire .titre-contact {
        font-size: 20px;
    }

    .contenu-formulaire p {
        font-size: 16px;
    }

    .champ {
        margin-bottom: 32px;
        font-size: 13px;
    }

    .etoile {
        font-size: 20px;
    }

    .candidature-feedback,
    .form-validation-summary {
        font-size: 15px;
    }

    .field-error {
        font-size: 13px;
    }

    .label-formulaire {
        font-size: 16px;
    }

    .form-candidature {
        grid-template-columns: 1fr;
        row-gap: 14px;
    }

    .bouton-candidature {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        text-align: center;
        font-size: 16px;
    }

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

    .contenu-info {
        flex-direction: column;
    }

    .colonne-texte {
        flex: none;
        max-width: none;
        width: 100%;
        padding: 40px 24px;
    }

    .colonne-map {
        flex: none;
        width: 100%;
        display: block;
    }

    .colonne-map iframe {
        flex: none;
        height: auto;
        aspect-ratio: 1100 / 480;
        min-height: 300px;
    }

    .titre-info {
        font-size: 20px;
        margin-bottom: 18px;
    }

    .texte-info {
        font-size: 16px;
        margin-bottom: 16px;
    }
}

@media (max-width: 480px) {
    .contenu-formulaire {
        padding: 24px 16px 32px;
        background-size: 240px, 280px;
        background-position: 120% 80%, 125% 100%;
    }

    .contenu-formulaire .titre-contact {
        font-size: 18px;
    }

    .contenu-formulaire p {
        font-size: 15px;
    }

    .champ {
        margin-bottom: 24px;
    }

    .candidature-feedback,
    .form-validation-summary {
        font-size: 14px;
        padding: 12px 14px;
    }

    .field-error {
        font-size: 13px;
        min-height: 1.2em;
    }

    .label-formulaire {
        font-size: 15px;
    }

    .form-candidature input,
    .form-candidature select,
    textarea {
        padding: 10px;
        font-size: 16px;
    }

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

    .colonne-texte {
        flex: none;
        max-width: none;
        width: 100%;
        padding: 28px 16px;
    }

    .colonne-map iframe {
        flex: none;
        height: auto;
        aspect-ratio: 1100 / 480;
        min-height: 240px;
    }

    .titre-info {
        font-size: 18px;
    }

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