/* Contact landing page — VirtualLab theme */

.vl-contact {
	--vl-contact-max: 1160px;
}

/* ---------- Hero ---------- */
.vl-contact-hero {
	position: relative;
	padding: var(--vl-sp-12) 0 var(--vl-sp-10);
	overflow: hidden;
	background: linear-gradient(180deg, rgba(30, 58, 138, 0.05), transparent 70%);
}
.vl-contact-hero__inner {
	position: relative;
	max-width: 860px;
	text-align: center;
	z-index: 1;
}
.vl-contact-hero__title {
	font-size: clamp(2rem, 4.2vw, 3.25rem);
	line-height: 1.15;
	margin: var(--vl-sp-3) 0 var(--vl-sp-4);
	letter-spacing: -0.01em;
}
.vl-contact-hero__lead {
	color: var(--vl-ink-muted);
	max-width: 680px;
	margin: 0 auto;
	font-size: 1.05rem;
}
.vl-contact-hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.vl-contact-hero__orb {
	position: absolute;
	top: -140px;
	right: -140px;
	width: 480px;
	height: 480px;
	border-radius: 50%;
	background: radial-gradient(circle at 35% 35%, rgba(14, 165, 183, 0.22), transparent 70%);
	filter: blur(30px);
}

/* ---------- Topic grid ---------- */
.vl-contact-topics {
	padding: var(--vl-sp-10) 0;
}
.vl-contact-topics__grid {
	display: grid;
	gap: var(--vl-sp-4);
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	margin-top: var(--vl-sp-6);
}
.vl-contact-topic {
	display: flex;
	flex-direction: column;
	gap: var(--vl-sp-2);
	padding: var(--vl-sp-6);
	border-radius: 16px;
	background: var(--vl-surface);
	border: 1px solid var(--vl-border);
	color: inherit;
	text-decoration: none;
	transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.vl-contact-topic:hover {
	border-color: var(--vl-accent);
	transform: translateY(-2px);
	box-shadow: 0 20px 40px -24px rgba(14, 165, 183, 0.35);
}
.vl-contact-topic__title {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0;
}
.vl-contact-topic__desc {
	color: var(--vl-ink-muted);
	font-size: .95rem;
	margin: 0;
	flex: 1;
}
.vl-contact-topic__cta {
	color: var(--vl-accent);
	font-weight: 600;
	font-size: .95rem;
}

/* ---------- Body (info + form) ---------- */
.vl-contact-body {
	padding: var(--vl-sp-10) 0;
	background: var(--vl-surface-soft, #F7F8FB);
}
.vl-contact-body__inner {
	display: grid;
	gap: var(--vl-sp-10);
	grid-template-columns: minmax(240px, 320px) 1fr;
	align-items: start;
}
@media (max-width: 820px) {
	.vl-contact-body__inner {
		grid-template-columns: 1fr;
		gap: var(--vl-sp-8);
	}
}

.vl-section-header--left {
	text-align: left;
	max-width: 560px;
	margin: 0 0 var(--vl-sp-5);
}

.vl-contact-info__list {
	display: flex;
	flex-direction: column;
	gap: var(--vl-sp-5);
	margin: 0;
}
.vl-contact-info__item dt {
	font-size: .78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--vl-ink-muted);
	font-weight: 600;
	margin-bottom: var(--vl-sp-1);
}
.vl-contact-info__item dd {
	margin: 0;
	font-size: 1.02rem;
	line-height: 1.5;
}
.vl-contact-info__item dd a {
	color: var(--vl-ink);
	text-decoration: none;
	border-bottom: 1px solid transparent;
}
.vl-contact-info__item dd a:hover {
	border-bottom-color: var(--vl-accent);
}
.vl-contact-info__note {
	color: var(--vl-ink-muted);
	font-size: .85rem;
	margin: 4px 0 0;
}

/* ---------- Form ---------- */
.vl-contact-form-wrap {
	background: #fff;
	border: 1px solid var(--vl-border);
	border-radius: 20px;
	padding: var(--vl-sp-8);
}
.vl-contact-form {
	display: flex;
	flex-direction: column;
	gap: var(--vl-sp-4);
}
.vl-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--vl-sp-4);
}
@media (max-width: 560px) {
	.vl-form-row {
		grid-template-columns: 1fr;
	}
}
.vl-form-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.vl-form-label {
	font-size: .85rem;
	font-weight: 600;
	color: var(--vl-ink);
}
.vl-form-field input,
.vl-form-field select,
.vl-form-field textarea {
	font: inherit;
	padding: 12px 14px;
	border-radius: 10px;
	border: 1px solid var(--vl-border);
	background: #fff;
	color: var(--vl-ink);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.vl-form-field input:focus,
.vl-form-field select:focus,
.vl-form-field textarea:focus {
	outline: none;
	border-color: var(--vl-accent);
	box-shadow: 0 0 0 3px rgba(14, 165, 183, 0.18);
}
.vl-form-field textarea {
	resize: vertical;
	min-height: 140px;
}
.vl-form-consent {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	font-size: .9rem;
	color: var(--vl-ink-muted);
	line-height: 1.5;
}
.vl-form-consent input[type="checkbox"] {
	margin-top: 4px;
}
.vl-form-consent a {
	color: var(--vl-accent);
	text-decoration: none;
}
.vl-contact-form__note {
	font-size: .85rem;
	color: var(--vl-ink-muted);
	margin: 0;
}

/* ---------- Map ---------- */
.vl-contact-map {
	padding: var(--vl-sp-10) 0 var(--vl-sp-12);
}
.vl-contact-map__frame {
	margin-top: var(--vl-sp-6);
	border-radius: 20px;
	overflow: hidden;
	border: 1px solid var(--vl-border);
	aspect-ratio: 16 / 7;
	min-height: 320px;
	background: #eef2f7;
}
.vl-contact-map__frame iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}
