
/* =======================
    FORMS
======================= */
#form-contacts {
    text-align: center;
    margin: 1.5em;
}
/* container */
.formulaire {
    max-width: 800px;
    margin: 3em auto;
    padding: 2em;

    display: flex;
    flex-direction: column;
    gap: 1.5em;

    background: var(--bg-doux);
    border: 1px solid var(--border-soft);
    border-radius: 12px;
}

/* rows */
.form-row {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

.form-row label {
    width: 180px;
    font-weight: 600;
    padding-top: 10px;
}

.input-container {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.input-container input,
.input-container textarea {
    width: 100%;
    padding: 12px 14px;

    border: 1px solid var(--border-soft);
    border-radius: 6px;

    font-family: var(--font-Google_Sans_Flex);
    font-size: 1rem;

    background: var(--bg);
    transition: all 0.2s ease;
}

.input-container input:hover,
.input-container textarea:hover {
    border-color: var(--accent);
}

.input-container input:focus,
.input-container textarea:focus {
    outline: none;
    border-color: var(--accent-hover);
    box-shadow: 0 0 0 2px rgba(255, 184, 120, 0.25);
}

.message-row textarea {
    min-height: 150px;
    resize: vertical;
}

.message-erreur-formulaire {
    margin-top: 5px;
    color: #f55145;
    font-weight: 600;
    font-size: 0.9rem;

    min-height: 1.2em;

    visibility: visible;
    opacity: 1;
    transition: opacity 0.2s ease;
}

.cacher {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
}

.controle-erreur {
    border-color: #f55145;
    box-shadow: 0 0 0 2px rgba(255, 0, 0, 0.4);
}

.form-bouton {
    text-align: center;
}

.form-bouton button {
    background: var(--accent);
    color: var(--text-principal);

    border: 1px solid var(--border-soft);
    padding: 12px 30px;

    border-radius: 50px;
    font-weight: 600;

    transition: all 0.25s ease;
}

.form-bouton button:hover {
    background: var(--accent-hover);
    transform: translateY(-2px);
}


/* =======================
    BOUTTONS
======================= */
.bouton-ajout {
    display: flex;
    justify-content: center;
    padding: 3em 0;
}

.bouton {
    display: inline-block;
    background-color: var(--accent);
    color: var(--text-principal);
    padding: 12px 35px;
    border-radius: 50px;
    font-weight: 600;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
    border: 2px solid var(--border-soft);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
}

.bouton:hover {
    background-color: var(--accent-hover);
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(255, 184, 120, 0.4);
} 
