/* Service page — VirtualLab theme */

.vl-service .vl-section-header {
	max-width: 720px;
	margin: 0 auto var(--vl-sp-6);
	text-align: center;
}
.vl-service .vl-section-header .vl-eyebrow { color: var(--vl-accent); }
.vl-service .vl-section-header .vl-h-section { margin: var(--vl-sp-2) 0 var(--vl-sp-3); }
.vl-service .vl-section-header__desc {
	color: var(--vl-muted);
	font-size: var(--vl-fs-lg);
	margin: 0;
	line-height: 1.55;
}

/* 한국어 어절 끊김 방지 — 핵심 헤딩들 */
.vl-service-hero__title,
.vl-service-hero__lead,
.vl-service-cta__title,
.vl-service .vl-h-section,
.vl-service-product__title,
.vl-service-custom__title {
	word-break: keep-all;
	overflow-wrap: break-word;
}

/* Elementor 호환 — 우리 hero 클래스를 Heading/Text Editor 위젯 래퍼에 적용해도
 * 안쪽 .elementor-heading-title / .elementor-widget-container p 에 우리 스타일 통과 */
.vl-service-hero__eyebrow.elementor-widget,
.vl-service-hero__title.elementor-widget,
.vl-service-hero__lead.elementor-widget {
	margin: 0;
}
.vl-service-hero__eyebrow.elementor-widget .elementor-heading-title {
	font: inherit; color: inherit; letter-spacing: inherit; text-transform: inherit;
}
.vl-service-hero__title.elementor-widget .elementor-heading-title {
	font: inherit; color: inherit; line-height: inherit; letter-spacing: inherit; margin: 0;
	background: inherit; -webkit-background-clip: inherit; background-clip: inherit; -webkit-text-fill-color: inherit;
}
.vl-service-hero__lead.elementor-widget p,
.vl-service-hero__lead.elementor-widget .elementor-widget-container {
	font: inherit; color: inherit; line-height: inherit; margin: 0;
}

/* Hero */
.vl-service-hero {
	padding: clamp(var(--vl-sp-8), 10vw, var(--vl-sp-10)) 0;
	background:
		radial-gradient(circle at 15% 15%, rgba(14, 165, 183, 0.2), transparent 50%),
		radial-gradient(circle at 85% 85%, rgba(59, 90, 191, 0.28), transparent 55%),
		linear-gradient(135deg, #0B1F4E 0%, #12306c 60%, #1E3A8A 100%);
	color: #F8FAFC;
}
.vl-service-hero__inner { max-width: 820px; }
.vl-service-hero__eyebrow { color: #A7F3EC; }
.vl-service-hero__title {
	font-size: clamp(var(--vl-fs-3xl), 5vw, var(--vl-fs-5xl));
	line-height: 1.1;
	color: #FFFFFF;
	margin: var(--vl-sp-3) 0 var(--vl-sp-4);
	letter-spacing: -0.02em;
	text-wrap: balance;
}
.vl-service-hero__lead {
	font-size: var(--vl-fs-xl);
	color: rgba(248, 250, 252, 0.88);
	margin: 0;
	line-height: 1.55;
	text-wrap: pretty;
}

/* Products grid */
.vl-service-products {
	padding: var(--vl-sp-10) 0;
	background: #FFFFFF;
}
.vl-service-products__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--vl-sp-5);
}
.vl-service-product {
	display: flex;
	flex-direction: column;
	position: relative;
	padding: var(--vl-sp-6);
	background: #FFFFFF;
	border: 1px solid var(--vl-border);
	border-radius: var(--vl-radius-lg);
	text-decoration: none;
	color: inherit;
	overflow: hidden;
	transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
	min-height: 240px;
}
.vl-service-product::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 4px;
	background: linear-gradient(90deg, #1E3A8A, #0EA5B7);
}
.vl-service-product:hover {
	transform: translateY(-3px);
	border-color: rgba(14, 165, 183, 0.4);
	box-shadow: 0 20px 44px -22px rgba(15, 23, 42, 0.22);
	color: inherit;
}
.vl-service-product__badge {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 999px;
	background: rgba(14, 165, 183, 0.12);
	color: var(--vl-accent);
	font-size: var(--vl-fs-xs);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--vl-sp-3);
	align-self: flex-start;
}
.vl-service-product__title {
	font-size: var(--vl-fs-2xl);
	font-weight: 800;
	color: var(--vl-ink);
	margin: 0 0 var(--vl-sp-2);
}
.vl-service-product__lead {
	color: var(--vl-muted);
	line-height: 1.55;
	margin: 0 0 var(--vl-sp-4);
	flex-grow: 1;
}
.vl-service-product__link {
	font-weight: 600;
	color: var(--vl-primary);
	align-self: flex-start;
}

@media (max-width: 900px) {
	.vl-service-products__grid { grid-template-columns: 1fr; }
}

/* Education row */
.vl-service-edu {
	padding: var(--vl-sp-10) 0;
	background: var(--vl-bg-soft);
}
.vl-service-edu__inner {
	max-width: 820px;
	margin: 0 auto;
	padding: var(--vl-sp-7);
	background: linear-gradient(135deg, rgba(30, 58, 138, 0.04), rgba(14, 165, 183, 0.06));
	border: 1px solid rgba(14, 165, 183, 0.18);
	border-radius: var(--vl-radius-lg);
}
.vl-service-edu__inner .vl-eyebrow { color: var(--vl-accent); }
.vl-service-edu__inner .vl-h-section {
	margin: var(--vl-sp-2) 0 var(--vl-sp-3);
	color: var(--vl-ink);
}
.vl-service-edu__lead {
	font-size: var(--vl-fs-lg);
	color: var(--vl-ink-700);
	margin: 0 0 var(--vl-sp-5);
	line-height: 1.6;
}

/* Custom engagement */
.vl-service-custom {
	padding: var(--vl-sp-10) 0;
	background: #FFFFFF;
}
.vl-service-custom__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--vl-sp-4);
}
.vl-service-custom__card {
	padding: var(--vl-sp-5);
	background: #FFFFFF;
	border: 1px solid var(--vl-border);
	border-radius: var(--vl-radius-lg);
	transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.vl-service-custom__card:hover {
	transform: translateY(-2px);
	border-color: rgba(14, 165, 183, 0.4);
	box-shadow: 0 16px 36px -22px rgba(15, 23, 42, 0.2);
}
.vl-service-custom__title {
	font-size: var(--vl-fs-lg);
	font-weight: 700;
	color: var(--vl-ink);
	margin: 0 0 var(--vl-sp-2);
}
.vl-service-custom__desc {
	margin: 0;
	color: var(--vl-muted);
	line-height: 1.55;
}

/* CTA */
.vl-service-cta {
	padding: var(--vl-sp-10) 0;
	background: linear-gradient(135deg, #0B1F4E 0%, #1E3A8A 100%);
	color: #F8FAFC;
	text-align: center;
}
.vl-service-cta__inner { max-width: 720px; }
.vl-service-cta__title {
	font-size: clamp(var(--vl-fs-3xl), 4vw, 2.5rem);
	color: #FFFFFF;
	margin: 0 0 var(--vl-sp-3);
	letter-spacing: -0.01em;
	text-wrap: balance;
}
.vl-service-cta__desc {
	font-size: var(--vl-fs-lg);
	color: rgba(248, 250, 252, 0.88);
	margin: 0 0 var(--vl-sp-5);
	line-height: 1.55;
}
.vl-service-cta__actions {
	display: inline-flex;
	gap: var(--vl-sp-3);
	flex-wrap: wrap;
	justify-content: center;
}
.vl-service-cta .vl-btn-primary { background: #0EA5B7; color: #0B1F4E; }
.vl-service-cta .vl-btn-primary:hover { background: #20BECF; }
.vl-service-cta .vl-btn-ghost { color: #F8FAFC; border-color: rgba(248, 250, 252, 0.4); }
.vl-service-cta .vl-btn-ghost:hover { background: rgba(248, 250, 252, 0.08); color: #F8FAFC; }
