.contact-form-container { max-width: 600px; margin: 2rem auto; padding: 2rem; }
.contact-form-container .contact-title { text-align: center; font-size: 1.8rem; margin-bottom: 1.5rem; color: var(--primary-color); }
.contact-form-container .contact-form { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; gap: 1rem; }
.contact-form-container .contact-form .contact-form-row { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; gap: 1rem; }
.contact-form-container .contact-form .contact-form-row .input-wrapper { -webkit-box-flex: 1; -ms-flex: 1 1 48%; flex: 1 1 48%; position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; }
.contact-form-container .contact-form .contact-form-row input { width: 100%; }
.contact-form-container .contact-form .contact-form-row input.error { border-color: red; }
.contact-form-container .contact-form .contact-form-row input#nom, .contact-form-container .contact-form .contact-form-row input#prenoms { text-transform: uppercase; }
.contact-form-container .contact-form .input-wrapper { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; }
.contact-form-container .contact-form input, .contact-form-container .contact-form textarea { width: 100%; padding: 1rem; border: 1px solid var(--primary-color); font-size: 1rem; resize: none; position: relative; -webkit-box-sizing: border-box; box-sizing: border-box; }
.contact-form-container .contact-form input:focus, .contact-form-container .contact-form textarea:focus { outline: none; -webkit-box-shadow: 0 0 0 2px var(--primary-color); box-shadow: 0 0 0 2px var(--primary-color); border-color: transparent; }
.contact-form-container .contact-form input.error, .contact-form-container .contact-form textarea.error { border-color: red; }
.contact-form-container .contact-form input.error:focus, .contact-form-container .contact-form textarea.error:focus { -webkit-box-shadow: 0 0 0 2px red; box-shadow: 0 0 0 2px red; border-color: transparent; }
.contact-form-container .contact-form button { padding: 1rem; background-color: var(--primary-color); border: none; font-weight: 600; cursor: pointer; text-transform: uppercase; color: var(--pure-white); }
.contact-form-container .contact-form button:focus { outline: none; -webkit-box-shadow: 0 0 0 2px var(--primary-color); box-shadow: 0 0 0 2px var(--primary-color); }
.contact-form-container .contact-form .contact-privacy-text { font-size: 0.9rem; text-align: left; color: var(--pure-black); }
.contact-form-container .contact-form .contact-privacy-text a { color: var(--primary-color); text-decoration: underline; }
.contact-form-container .contact-form .help-text { font-size: 0.9rem; color: red; display: none; margin-top: 0.5rem; }
.contact-form-container .contact-form .error + .help-text { display: block; text-align: left; }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

.contact-subtitle { margin-bottom: 2rem; font-size: 1.1rem; color: var(--text-color, #444); line-height: 1.5; }

.help-text.error-text { font-size: 0.85rem; margin-top: 0.3rem; color: red; }

@media (max-width: 500px) { .contact-form .contact-form-row .input-wrapper { -webkit-box-flex: 1; -ms-flex: 1 1 100%; flex: 1 1 100%; }
  .contact-form button { width: 100%; } }
