/*
 * Contact / request form styling.
 * Scoped under .contact-form-shell so the redesign stays isolated from
 * the legacy training/offer styles that share trainingoffering.css.
 */

.contact-form-shell {
	--cf-orange: #ff8c00;
	--cf-orange-dark: #d97500;
	--cf-orange-deep: #ff6600;
	--cf-text: #1f2933;
	--cf-text-muted: #5c6470;
	--cf-border: #e3e6ec;
	--cf-border-strong: #cfd3da;
	--cf-bg: #ffffff;
	--cf-bg-soft: #f7f8fb;
	--cf-radius: 16px;
	--cf-radius-sm: 10px;
	--cf-shadow: 0 20px 60px -20px rgba(15, 30, 60, 0.18),
		0 8px 24px -16px rgba(15, 30, 60, 0.10);
	--cf-focus: 0 0 0 4px rgba(255, 140, 0, 0.18);

	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding: 48px 16px 64px;
	background:
		radial-gradient(1200px 400px at 50% -120px,
			rgba(255, 140, 0, 0.08), transparent 70%),
		linear-gradient(180deg, #fafbfd 0%, #f1f3f7 100%);
	min-height: 100%;
}

.contact-form-card {
	width: 100%;
	max-width: 760px;
	background: var(--cf-bg);
	border: 1px solid var(--cf-border);
	border-radius: var(--cf-radius);
	box-shadow: var(--cf-shadow);
	padding: 40px 44px 36px;
	position: relative;
	overflow: hidden;
}

.contact-form-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, #ff8c00 0%, #ff6600 60%, #d97500 100%);
}

.contact-form-header {
	text-align: center;
	margin-bottom: 32px;
}

.contact-form-title {
	font-family: "DejaVu Sans", sans-serif;
	font-size: clamp(1.5rem, 2.4vw + 1rem, 2rem);
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--cf-text);
	margin: 0 0 10px;
}

.contact-form-subtitle {
	font-size: 15px;
	line-height: 1.55;
	color: var(--cf-text-muted);
	margin: 0 auto;
	max-width: 52ch;
}

.contact-form .form-group {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	margin-bottom: 18px;
}

.contact-form .fields,
.contact-form .fields-double {
	display: flex;
	flex-direction: column;
	flex: 1 1 240px;
	min-width: 0;
	border: 0;
	padding: 0;
	margin: 0;
}

.contact-form .fields-double {
	flex-basis: 100%;
}

.contact-form .form-label {
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: var(--cf-text);
	margin-bottom: 8px;
}

.contact-form .form-input {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	font: inherit;
	font-size: 15px;
	color: var(--cf-text);
	padding: 12px 14px;
	background: var(--cf-bg);
	border: 1px solid var(--cf-border-strong);
	border-radius: var(--cf-radius-sm);
	transition: border-color 0.18s ease, box-shadow 0.18s ease,
		background 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
}

.contact-form .form-input::placeholder {
	color: #a8aeb8;
}

.contact-form .form-input:hover {
	border-color: #b9bec7;
}

.contact-form .form-input:focus,
.contact-form .form-input:focus-visible {
	outline: none;
	border-color: var(--cf-orange);
	box-shadow: var(--cf-focus);
	background: #fffdf8;
}

.contact-form .form-input.form-input--invalid:invalid {
	border-color: #c0392b;
	box-shadow: 0 0 0 4px rgba(192, 57, 43, 0.12);
}

.contact-form textarea.form-input {
	resize: vertical;
	min-height: 140px;
	line-height: 1.55;
}

.contact-form .prefilled {
	display: flex;
	align-items: center;
	min-height: 44px;
	background: var(--cf-bg-soft);
	color: var(--cf-text);
	font-weight: 500;
	border-style: dashed;
}

.form-group--captcha {
	justify-content: center;
	margin-top: 8px;
	margin-bottom: 4px;
}

.form-consent {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 18px 0 8px;
	padding: 14px 16px;
	background: var(--cf-bg-soft);
	border: 1px solid var(--cf-border);
	border-radius: var(--cf-radius-sm);
}

.form-consent .form-checkbox {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin: 2px 0 0;
	accent-color: var(--cf-orange);
	cursor: pointer;
}

.form-consent label {
	font-size: 14px;
	line-height: 1.5;
	color: var(--cf-text-muted);
	cursor: pointer;
	user-select: none;
}

.form-actions {
	margin-top: 24px;
	display: flex;
	justify-content: flex-end;
}

.contact-form .request-button {
	font: inherit;
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: #fff;
	background: linear-gradient(135deg, #ff8c00 0%, #ff6e00 100%);
	border: 1px solid var(--cf-orange-dark);
	border-radius: var(--cf-radius-sm);
	padding: 13px 32px;
	cursor: pointer;
	box-shadow: 0 6px 16px -6px rgba(255, 110, 0, 0.55);
	transition: transform 0.15s ease, box-shadow 0.15s ease,
		background 0.15s ease, filter 0.15s ease;
	min-width: 180px;
}

.contact-form .request-button:hover {
	background: linear-gradient(135deg, #ff7700 0%, var(--cf-orange-deep) 100%);
	transform: translateY(-1px);
	box-shadow: 0 10px 22px -8px rgba(255, 110, 0, 0.65);
}

.contact-form .request-button:active {
	transform: translateY(0);
	box-shadow: 0 4px 10px -4px rgba(255, 110, 0, 0.55);
}

.contact-form .request-button:focus-visible {
	outline: none;
	box-shadow: var(--cf-focus), 0 6px 16px -6px rgba(255, 110, 0, 0.55);
}

.contact-form .message--danger {
	display: block;
	color: #c0392b;
	font-size: 14px;
	margin-top: 8px;
}

@media (max-width: 720px) {
	.contact-form-shell {
		padding: 24px 12px 40px;
	}

	.contact-form-card {
		padding: 28px 20px 24px;
		border-radius: 14px;
	}

	.contact-form-header {
		margin-bottom: 22px;
	}

	.contact-form .form-group {
		gap: 14px;
		margin-bottom: 14px;
	}

	.contact-form .fields,
	.contact-form .fields-double {
		flex-basis: 100%;
	}

	.form-actions {
		justify-content: stretch;
	}

	.contact-form .request-button {
		width: 100%;
		min-width: 0;
		padding: 14px 20px;
	}
}

@media (max-width: 380px) {
	.contact-form-card {
		padding: 22px 16px 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.contact-form .form-input,
	.contact-form .request-button {
		transition: none;
	}

	.contact-form .request-button:hover {
		transform: none;
	}
}
