/* ================================
   DG Services Showcase
================================ */

.dg-services-showcase {
	position: relative;
	width: 100vw;
	max-width: 100vw;
	margin-right: calc(50% - 50vw);
	margin-left: calc(50% - 50vw);
	padding: 96px 20px 104px;
	overflow: hidden;
	background: var(--dg-bg, #1c1c1c);
	color: var(--dg-text, #ffffff);
}

.dg-services-showcase,
.dg-services-showcase * {
	box-sizing: border-box;
}

.dg-services-showcase-inner {
	width: min(100%, 1480px);
	margin: 0 auto;
}

.dg-services-showcase-list {
	display: flex;
	flex-direction: column;
	gap: 92px;
}

.dg-service-block {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(420px, 0.92fr);
	align-items: center;
	gap: clamp(44px, 6vw, 88px);
}

.dg-service-block.is-media-left {
	grid-template-columns: minmax(420px, 0.92fr) minmax(0, 1fr);
}

.dg-service-block.is-media-left .dg-service-copy {
	order: 2;
}

.dg-service-block.is-media-left .dg-service-visual-card {
	order: 1;
}

.dg-service-copy {
	min-width: 0;
}

.dg-service-title {
	margin: 0;
	color: #ffffff;
	font-family: var(--dg-font-heading, "TT Firs Neue", "Montserrat", Arial, sans-serif);
	font-size: clamp(42px, 4.2vw, 56px);
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0;
}

.dg-service-description {
	max-width: 720px;
	margin-top: 28px;
	color: var(--dg-text-muted, rgba(255, 255, 255, 0.68));
	font-family: var(--dg-font-body, "Montserrat", Arial, sans-serif);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.55;
}

.dg-service-description p {
	margin: 0;
}

.dg-service-included-title {
	margin: 34px 0 0;
	color: #ffffff;
	font-family: var(--dg-font-heading, "TT Firs Neue", "Montserrat", Arial, sans-serif);
	font-size: clamp(30px, 2.6vw, 42px);
	font-weight: 500;
	line-height: 1.08;
	letter-spacing: 0;
}

.dg-service-included-list {
	display: grid;
	gap: 17px;
	margin: 28px 0 0;
	padding: 0;
	color: #ffffff;
	font-family: var(--dg-font-body, "Montserrat", Arial, sans-serif);
	font-size: clamp(16px, 1.25vw, 20px);
	font-weight: 600;
	line-height: 1.35;
	list-style: none;
}

.dg-service-included-list li {
	position: relative;
	padding-left: 22px;
}

.dg-service-included-list li::before {
	content: "";
	position: absolute;
	top: 0.64em;
	left: 0;
	width: 6px;
	height: 6px;
	border-radius: 999px;
	background: var(--dg-text-muted, rgba(255, 255, 255, 0.68));
	transform: translateY(-50%);
}

.dg-service-visual-card {
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.018)),
		rgba(255, 255, 255, 0.032);
	border: 1px solid rgba(255, 255, 255, 0.10);
	border-radius: 24px;
	box-shadow:
		0 28px 80px rgba(0, 0, 0, 0.24),
		inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.dg-service-media {
	position: relative;
	width: 100%;
	overflow: hidden;
	aspect-ratio: 16 / 9;
	background: #141414;
}

.dg-service-image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dg-service-card-content {
	padding: clamp(32px, 4vw, 52px);
	text-align: center;
}

.dg-service-card-title {
	margin: 0;
	color: #ffffff;
	font-family: var(--dg-font-heading, "TT Firs Neue", "Montserrat", Arial, sans-serif);
	font-size: clamp(30px, 2.7vw, 42px);
	font-weight: 500;
	line-height: 1.08;
	letter-spacing: 0;
}

.dg-service-card-text {
	max-width: 560px;
	margin: 22px auto 0;
	color: var(--dg-text-muted, rgba(255, 255, 255, 0.68));
	font-family: var(--dg-font-body, "Montserrat", Arial, sans-serif);
	font-size: clamp(16px, 1.3vw, 20px);
	font-weight: 500;
	line-height: 1.55;
}

.dg-service-card-text p {
	margin: 0;
}

.dg-service-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	margin-top: 30px;
	padding: 15px 26px;
	border: 1px solid var(--dg-accent, #11e44f);
	border-radius: 14px;
	background: var(--dg-accent, #11e44f);
	color: #0b0b0b;
	font-family: var(--dg-font-body, "Montserrat", Arial, sans-serif);
	font-size: 15px;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	box-shadow: 0 14px 34px rgba(17, 228, 79, 0.18);
	transition:
		transform 0.22s ease,
		background-color 0.22s ease,
		border-color 0.22s ease,
		box-shadow 0.22s ease;
}

.dg-service-button:hover {
	background: var(--dg-accent-hover, #0fd145);
	border-color: var(--dg-accent-hover, #0fd145);
	transform: translateY(-2px);
	box-shadow: 0 18px 48px rgba(17, 228, 79, 0.24);
}

@media (max-width: 1180px) {
	.dg-service-block,
	.dg-service-block.is-media-left {
		grid-template-columns: minmax(0, 1fr);
		gap: 38px;
	}

	.dg-service-block.is-media-left .dg-service-copy,
	.dg-service-block.is-media-left .dg-service-visual-card {
		order: initial;
	}
}

@media (max-width: 767px) {
	.dg-services-showcase {
		width: 100%;
		max-width: 100%;
		margin-right: 0;
		margin-left: 0;
		padding: 70px 20px 78px;
	}

	.dg-services-showcase-list {
		gap: 72px;
	}

	.dg-service-block {
		gap: 34px;
	}

	.dg-service-title {
		font-size: clamp(40px, 12vw, 56px);
		line-height: 1;
	}

	.dg-service-description {
		margin-top: 22px;
		font-size: 16px;
		line-height: 1.58;
	}

	.dg-service-included-title {
		margin-top: 30px;
		font-size: 31px;
	}

	.dg-service-included-list {
		gap: 15px;
		margin-top: 24px;
		font-size: 16px;
	}

	.dg-service-visual-card {
		border-radius: 20px;
	}

	.dg-service-media {
		aspect-ratio: 16 / 9;
	}

	.dg-service-card-content {
		padding: 32px 22px 36px;
	}

	.dg-service-card-title {
		font-size: 31px;
	}

	.dg-service-card-text {
		margin-top: 18px;
		font-size: 16px;
	}

	.dg-service-button {
		width: 100%;
		min-height: 52px;
		margin-top: 26px;
	}
}

@media (max-width: 390px) {
	.dg-services-showcase {
		padding-right: 16px;
		padding-left: 16px;
	}

	.dg-service-title {
		font-size: 38px;
	}

	.dg-service-card-content {
		padding-right: 18px;
		padding-left: 18px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.dg-service-button {
		transition: none;
	}
}
