/**
 * Ninja Forms — page contact : champs arrondis, focus discret
 */
.sec-contact.gradient-tr {
	--gradient-color: #b2b2f9;
}

.sec-contact {
	color: var(--c-dark);
}

.sec-contact a {
	color: var(--c-dark);
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.sec-contact a:hover {
	opacity: 0.75;
}

.sec-contact .nf-form-wrap,
.sec-contact .nf-form-content {
	max-width: 100%;
}

.sec-contact .nf-field-container {
	margin-bottom: 1.1rem;
}

.sec-contact .nf-field-label label {
	font-size: var(--t7, 0.875rem);
	font-weight: 500;
	color: var(--c-dark);
	margin-bottom: 0.35rem;
	display: inline-block;
}

.sec-contact .nf-field-wrap.label-above,
.sec-contact .label-above.nf-field-wrap {
	position: relative;
}

.sec-contact .label-above .nf-field-label {
	margin-bottom: 10px;
	position: absolute;
	z-index: 999999;
	right: 10px;
	top: 5px;
}

.sec-contact .nf-field-element input[type="text"],
.sec-contact .nf-field-element input[type="email"],
.sec-contact .nf-field-element input[type="tel"],
.sec-contact .nf-field-element input[type="url"],
.sec-contact .nf-field-element input[type="number"],
.sec-contact .nf-field-element input[type="date"],
.sec-contact .nf-field-element input[type="password"],
.sec-contact .nf-field-element textarea,
.sec-contact .nf-field-element select {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 0.7rem 1rem;
	font-size: var(--t6, 1rem);
	font-family: inherit;
	line-height: 1.4;
	color: var(--c-dark, #111);
	background: var(--c-white, #fff);
	border: 1px solid var(--c-grey-soft, #e0e0e0);
	border-radius: 12px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	-webkit-appearance: none;
	appearance: none;
}

.sec-contact .nf-field-element textarea {
	min-height: 8rem;
	resize: vertical;
	border-radius: 14px;
}

.sec-contact .nf-field-element select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
	background-size: 16px;
	padding-right: 2.5rem;
}

.sec-contact .nf-field-element input:focus,
.sec-contact .nf-field-element textarea:focus,
.sec-contact .nf-field-element select:focus {
	outline: none;
	border-color: color-mix(in srgb, var(--c-fresh-2, #5a1eff) 45%, var(--c-grey-soft, #e0e0e0));
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-fresh-2, #5a1eff) 16%, transparent);
}

.sec-contact .nf-field-element input::placeholder,
.sec-contact .nf-field-element textarea::placeholder {
	color: color-mix(in srgb, var(--c-grey, #666) 55%, transparent);
}

/* Bouton envoi — aligné sur .btn (btn.css) */
.sec-contact input.nf-element[type="submit"],
.sec-contact input.ninja-forms-field[type="submit"],
.sec-contact .nf-field-submit input[type="submit"],
.sec-contact .nf-field-submit input[type="button"],
.sec-contact .nf-field-submit .nf-element,
.sec-contact .nf-field-submit button {
	position: relative;
	background: var(--c-fresh);
	box-shadow: 0 4px 14px rgba(30, 95, 168, 0.25);
	transition: all 0.25s ease-out, box-shadow 0.5s cubic-bezier(0.4, 0, 0.2, 1);
	white-space: nowrap;
	border: 0;
	padding: calc(var(--gap) / 2) calc(var(--gap) * 1);
	border-radius: 50px;
	font-weight: 600;
	text-align: center;
	color: var(--c-white) !important;
	text-decoration: none;
	font-size: var(--t6);
	margin-top: calc(var(--gap) * 1);
	display: inline-block;
	cursor: pointer;
	font-family: inherit;
	line-height: 1.3;
	-webkit-appearance: none;
	appearance: none;
}

.sec-contact input.nf-element[type="submit"]:hover,
.sec-contact input.ninja-forms-field[type="submit"]:hover,
.sec-contact .nf-field-submit input[type="submit"]:hover,
.sec-contact .nf-field-submit input[type="button"]:hover,
.sec-contact .nf-field-submit .nf-element:hover,
.sec-contact .nf-field-submit button:hover {
	box-shadow: 0 8px 24px rgba(30, 95, 168, 0.4);
	transform: translateY(-1px);
	color: var(--c-white) !important;
	text-decoration: none;
}

/* Messages d’erreur Ninja */
.sec-contact .nf-error-msg,
.sec-contact .nf-error.field-wrap .nf-field-element::after {
	font-size: var(--t8, 0.75rem);
}

.sec-contact .nf-error .nf-field-element input,
.sec-contact .nf-error .nf-field-element textarea,
.sec-contact .nf-error .nf-field-element select {
	border-color: color-mix(in srgb, #c00 35%, var(--c-grey-soft));
}
