:root {
	--vision-contact-overlay: rgba(2, 6, 9, 0.78);
	--vision-contact-surface: linear-gradient(155deg, rgba(8, 15, 20, 0.96), rgba(3, 7, 10, 0.98));
	--vision-contact-border: rgba(152, 191, 169, 0.24);
	--vision-contact-text: #ecf4ff;
	--vision-contact-text-soft: rgba(220, 235, 250, 0.78);
	--vision-contact-accent: #93b8a3;
	--vision-contact-danger: #ff7f8e;
}

html.vision-contact-modal-open,
body.vision-contact-modal-open {
	overflow: hidden;
}

.vision-contact-modal {
	position: fixed;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(16px, 2vw, 30px);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	z-index: 99999;
	transition: opacity 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), visibility 0s linear 0.3s;
	will-change: opacity;
}

.vision-contact-modal.is-open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transition-delay: 0s, 0s;
}

.vision-contact-modal.is-closing {
	opacity: 0;
	visibility: visible;
	pointer-events: none;
	transition-delay: 0s, 0s;
}

.vision-contact-modal__overlay {
	position: absolute;
	inset: 0;
	background: var(--vision-contact-overlay);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}

.vision-contact-modal__dialog {
	position: relative;
	width: min(100%, 720px);
	max-height: min(90vh, 900px);
	overflow: auto;
	padding: clamp(20px, 2.2vw, 32px);
	border-radius: 24px;
	border: 1px solid var(--vision-contact-border);
	background: var(--vision-contact-surface);
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(120, 160, 140, 0.08) inset;
	transform: translateY(12px) scale(0.985);
	opacity: 0;
	transition: transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.3s ease;
	color: var(--vision-contact-text);
	will-change: transform, opacity;
}

.vision-contact-modal.is-open .vision-contact-modal__dialog,
.vision-contact-modal.is-closing .vision-contact-modal__dialog {
	opacity: 1;
	transform: translateY(0) scale(1);
}

.vision-contact-modal.is-closing .vision-contact-modal__dialog {
	opacity: 0;
	transform: translateY(8px) scale(0.992);
}

.vision-contact-modal__close {
	position: absolute;
	top: 12px;
	right: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	width: 38px;
	height: 38px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(7, 12, 16, 0.64);
	color: #fff;
	cursor: pointer;
	font-size: 24px;
	line-height: 1;
}

.vision-contact-modal__close span {
	display: block;
	line-height: 1;
	transform: translateY(-1px);
}

.vision-contact-modal__close:hover,
.vision-contact-modal__close:focus-visible {
	background: rgba(19, 34, 26, 0.85);
	outline: none;
}

.vision-contact-modal__header {
	margin-bottom: 16px;
	padding-right: 44px;
}

.vision-contact-modal__title {
	margin: 0 0 8px;
	font-size: clamp(26px, 3vw, 38px);
	line-height: 1.02;
	letter-spacing: 0.01em;
	color: #fff;
}

.vision-contact-modal__subtitle {
	margin: 0;
	font-size: 15px;
	line-height: 1.45;
	color: var(--vision-contact-text-soft);
}

.vision-contact-modal__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: 10px 16px;
	margin: 0;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid rgba(147, 184, 163, 0.24);
	background: rgba(11, 18, 24, 0.7);
}

.vision-contact-modal__instagram-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #dff0e7;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	line-height: 1.2;
}

.vision-contact-modal__instagram-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 999px;
	border: 1px solid rgba(223, 240, 231, 0.35);
	background: rgba(10, 19, 16, 0.55);
}

.vision-contact-modal__instagram-icon svg {
	width: 14px;
	height: 14px;
	display: block;
}

.vision-contact-modal__instagram-text {
	text-decoration: underline;
	text-decoration-color: rgba(223, 240, 231, 0.35);
	text-underline-offset: 3px;
}

.vision-contact-modal__instagram-link:hover,
.vision-contact-modal__instagram-link:focus-visible {
	color: #fff;
}

.vision-contact-modal__instagram-link:hover .vision-contact-modal__instagram-text,
.vision-contact-modal__instagram-link:focus-visible .vision-contact-modal__instagram-text {
	text-decoration-color: rgba(255, 255, 255, 0.72);
}

.vision-contact-modal__instagram-link:hover .vision-contact-modal__instagram-icon,
.vision-contact-modal__instagram-link:focus-visible .vision-contact-modal__instagram-icon {
	border-color: rgba(255, 255, 255, 0.72);
	outline: none;
}

.vision-contact-modal__response-time {
	margin: 8px 0 14px;
	color: var(--vision-contact-text-soft);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.01em;
}

.vision-contact-modal__feedback {
	min-height: 0;
	margin-bottom: 0;
	font-size: 14px;
	line-height: 1.4;
	color: var(--vision-contact-text-soft);
}

.vision-contact-modal__feedback.is-error,
.vision-contact-modal__feedback.is-loading {
	margin-bottom: 12px;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(7, 12, 16, 0.58);
}

.vision-contact-modal__feedback.is-error {
	border-color: rgba(255, 126, 142, 0.44);
	color: #ffd8de;
}

.vision-contact-modal__content {
	position: relative;
}

.vision-contact-modal__loading {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--vision-contact-text-soft);
}

.vision-contact-modal__spinner {
	width: 16px;
	height: 16px;
	border-radius: 999px;
	border: 2px solid rgba(255, 255, 255, 0.22);
	border-top-color: #fff;
	animation: vision-contact-spin 0.8s linear infinite;
}

@keyframes vision-contact-spin {
	to {
		transform: rotate(360deg);
	}
}

.vision-contact-modal .wpcf7 form {
	display: grid;
	gap: 12px;
}

.vision-contact-modal .wpcf7 form p {
	margin: 0;
}

.vision-contact-modal .wpcf7-form-control {
	width: 100%;
	min-height: 46px;
	padding: 10px 14px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(4, 9, 13, 0.78);
	color: #fff;
}

.vision-contact-modal textarea.wpcf7-form-control {
	min-height: 120px;
	resize: vertical;
}

.vision-contact-modal .wpcf7-form-control:focus-visible {
	outline: none;
	border-color: var(--vision-contact-accent);
	box-shadow: 0 0 0 3px rgba(144, 185, 162, 0.2);
}

.vision-contact-modal .wpcf7-submit,
.vision-contact-modal .wpcf7 input.wpcf7-submit,
.vision-contact-modal .wpcf7 form input[type="submit"].wpcf7-submit {
	min-height: 46px;
	padding: 10px 20px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.42) !important;
	background: #fff !important;
	color: #061015 !important;
	-webkit-text-fill-color: #061015 !important;
	font-weight: 700;
	cursor: pointer;
}

.vision-contact-modal .wpcf7-submit:hover,
.vision-contact-modal .wpcf7-submit:focus-visible,
.vision-contact-modal .wpcf7 input.wpcf7-submit:hover,
.vision-contact-modal .wpcf7 input.wpcf7-submit:focus-visible,
.vision-contact-modal .wpcf7 form input[type="submit"].wpcf7-submit:hover,
.vision-contact-modal .wpcf7 form input[type="submit"].wpcf7-submit:focus-visible {
	background: #dff0e7 !important;
	color: #061015 !important;
	-webkit-text-fill-color: #061015 !important;
	outline: none;
}

.vision-contact-modal .wpcf7-submit.is-loading {
	opacity: 0.72;
	cursor: progress;
}

.vision-contact-modal .wpcf7-not-valid-tip {
	margin-top: 6px;
	font-size: 12px;
	color: #ffd3dc;
}

.vision-contact-modal .wpcf7-response-output {
	display: none !important;
}

.vision-contact-modal .wpcf7 form.invalid .wpcf7-response-output,
.vision-contact-modal .wpcf7 form.failed .wpcf7-response-output,
.vision-contact-modal .wpcf7 form.spam .wpcf7-response-output,
.vision-contact-modal .wpcf7 form.aborted .wpcf7-response-output {
	border-color: rgba(255, 126, 142, 0.5);
	background: rgba(90, 24, 33, 0.24);
	color: #ffd8de;
}

.vision-contact-modal .wpcf7 form.sent .wpcf7-response-output {
	border-color: rgba(131, 205, 165, 0.56);
	background: rgba(18, 67, 43, 0.26);
	color: #dff9e8;
}

.vision-contact-captcha {
	display: grid;
	grid-template-columns: 1fr auto 84px;
	align-items: center;
	gap: 8px;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(3, 8, 12, 0.72);
}

.vision-contact-captcha__label {
	font-size: 13px;
	color: var(--vision-contact-text-soft);
}

.vision-contact-captcha__refresh {
	min-width: 34px;
	height: 34px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.24);
	background: rgba(8, 14, 19, 0.72);
	color: #fff;
	cursor: pointer;
	font-size: 16px;
}

.vision-contact-captcha__refresh:hover,
.vision-contact-captcha__refresh:focus-visible {
	border-color: var(--vision-contact-accent);
	outline: none;
}

.vision-contact-captcha__input {
	width: 100% !important;
	min-height: 36px;
	padding: 8px 10px;
	text-align: center;
	font-weight: 700;
}

.vision-contact-modal__success {
	padding: 16px;
	border-radius: 14px;
	border: 1px solid rgba(133, 209, 171, 0.56);
	background: rgba(18, 69, 45, 0.28);
}

.vision-contact-modal__success h3 {
	margin: 0 0 8px;
	font-size: 20px;
	color: #eafff3;
}

.vision-contact-modal__success p {
	margin: 0 0 12px;
	font-size: 14px;
	color: #dbfce8;
}

.vision-contact-modal__success-close {
	min-height: 42px;
	padding: 9px 18px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.42);
	background: #fff;
	color: #061015;
	font-weight: 700;
	cursor: pointer;
}

@media (max-width: 767px) {
	.vision-contact-modal {
		padding: 12px;
	}

	.vision-contact-modal__dialog {
		width: 100%;
		max-height: 92vh;
		padding: 18px;
		border-radius: 16px;
	}

	.vision-contact-captcha {
		grid-template-columns: 1fr auto;
	}

	.vision-contact-captcha__input {
		grid-column: 1 / -1;
	}
}

@media (prefers-reduced-motion: reduce) {
	.vision-contact-modal,
	.vision-contact-modal__dialog,
	.vision-contact-modal__spinner {
		transition: none !important;
		animation: none !important;
	}
}
