/* ==========================================================================
   ARSpneu — Hero Section & Service Cards
   3–4. Fázis: Hero szekció + Szolgáltatás kártyák
   ========================================================================== */

/* --------------------------------------------------------------------------
   Hero Section
   -------------------------------------------------------------------------- */
.dt-hero {
	position: relative;
	min-height: 520px;
	display: flex;
	align-items: center;
	overflow: hidden;
}

/* Background image layer */
.dt-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center right;
	background-repeat: no-repeat;
	z-index: 1;
}

/* Gradient overlay — bal oldal fehér a szöveg olvashatóságáért */
.dt-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		rgba(255, 255, 255, 0.95) 0%,
		rgba(255, 255, 255, 0.88) 35%,
		rgba(255, 255, 255, 0.6) 55%,
		rgba(255, 255, 255, 0.2) 75%,
		transparent 100%
	);
	z-index: 2;
}

/* Content */
.dt-hero__content {
	position: relative;
	z-index: 3;
	max-width: var(--dt-container-max);
	margin: 0 auto;
	padding: var(--dt-space-3xl) var(--dt-space-xl);
	width: 100%;
}

/* Title */
.dt-hero__title {
	font-family: var(--dt-font-heading);
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	font-weight: 800;
	line-height: 1.05;
	color: var(--dt-color-text-heading);
	text-transform: uppercase;
	letter-spacing: -0.02em;
	margin: 0 0 var(--dt-space-lg);
	max-width: 550px;
}

/* Subtitle */
.dt-hero__subtitle {
	font-family: var(--dt-font-body);
	font-size: clamp(1rem, 2vw, 1.25rem);
	font-weight: 400;
	line-height: var(--dt-line-height-relaxed);
	color: var(--dt-color-text-light);
	margin: 0 0 var(--dt-space-xl);
	max-width: 460px;
}

/* CTA Button */
.dt-hero__cta {
	font-size: var(--dt-font-size-md) !important;
	padding: 1em 2.5em !important;
	box-shadow: var(--dt-shadow-lg);
}

.dt-hero__cta:hover {
	box-shadow: 0 8px 32px rgba(255, 213, 8, 0.35);
}

/* --------------------------------------------------------------------------
   Hero Animations — Slide Up + Fade In
   -------------------------------------------------------------------------- */
.dt-animate-slide-up {
	opacity: 0;
	transform: translateY(30px);
	animation: dtSlideUp 0.7s ease forwards;
}

.dt-animate-fade-up {
	opacity: 0;
	transform: translateY(20px);
	animation: dtSlideUp 0.6s ease forwards;
}

.dt-delay-0 { animation-delay: 0.1s; }
.dt-delay-1 { animation-delay: 0.25s; }
.dt-delay-2 { animation-delay: 0.4s; }
.dt-delay-3 { animation-delay: 0.55s; }
.dt-delay-4 { animation-delay: 0.7s; }

@keyframes dtSlideUp {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* --------------------------------------------------------------------------
   Service Cards Section
   -------------------------------------------------------------------------- */
.dt-services {
	position: relative;
	z-index: 4;
	margin-top: -50px;
	padding: 0 var(--dt-space-xl) var(--dt-space-2xl);
}

.dt-services__grid {
	max-width: var(--dt-container-max);
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: var(--dt-space-lg);
}

/* Card */
.dt-service-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--dt-space-md);
	background: var(--dt-color-bg-white);
	border-radius: var(--dt-radius-lg);
	padding: var(--dt-space-xl) var(--dt-space-lg);
	box-shadow: var(--dt-shadow-md);
	text-decoration: none;
	transition: all var(--dt-transition-base);
	cursor: pointer;
	border: 2px solid transparent;
}

.dt-service-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--dt-shadow-xl);
	border-color: var(--dt-color-primary);
}

/* Icon */
.dt-service-card__icon {
	width: 56px;
	height: 56px;
	color: var(--dt-color-secondary);
	transition: color var(--dt-transition-base);
}

.dt-service-card__icon svg {
	width: 100%;
	height: 100%;
}

.dt-service-card__icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: var(--dt-radius-md);
}

.dt-service-card:hover .dt-service-card__icon {
	color: var(--dt-color-primary);
}

/* Title */
.dt-service-card__title {
	font-family: var(--dt-font-heading);
	font-size: var(--dt-font-size-sm);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: var(--dt-letter-spacing-wide);
	color: var(--dt-color-text-heading);
	text-align: center;
	margin: 0;
	transition: color var(--dt-transition-base);
}

.dt-service-card:hover .dt-service-card__title {
	color: var(--dt-color-primary);
}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */

/* Tablet */
@media (max-width: 1024px) {
	.dt-hero {
		min-height: 420px;
	}

	.dt-hero__content {
		padding: var(--dt-space-2xl) var(--dt-space-lg);
	}

	.dt-services__grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--dt-space-md);
	}

	.dt-service-card {
		padding: var(--dt-space-lg) var(--dt-space-md);
	}

	.dt-service-card__icon {
		width: 44px;
		height: 44px;
	}
}

/* Mobile */
@media (max-width: 767px) {
	.dt-hero {
		min-height: 380px;
	}

	.dt-hero__overlay {
		background: linear-gradient(
			180deg,
			rgba(255, 255, 255, 0.92) 0%,
			rgba(255, 255, 255, 0.75) 60%,
			rgba(255, 255, 255, 0.4) 100%
		);
	}

	.dt-hero__bg {
		background-position: center center;
	}

	.dt-hero__content {
		padding: var(--dt-space-2xl) var(--dt-space-md);
		text-align: center;
	}

	.dt-hero__title {
		max-width: none;
	}

	.dt-hero__subtitle {
		max-width: none;
	}

	.dt-hero__actions {
		display: flex;
		justify-content: center;
	}

	.dt-services {
		margin-top: -30px;
		padding: 0 var(--dt-space-md) var(--dt-space-xl);
	}

	.dt-services__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--dt-space-md);
	}

	.dt-service-card {
		padding: var(--dt-space-lg) var(--dt-space-sm);
	}

	.dt-service-card__icon {
		width: 40px;
		height: 40px;
	}

	.dt-service-card__title {
		font-size: var(--dt-font-size-xs);
	}
}

/* Small mobile */
@media (max-width: 480px) {
	.dt-hero {
		min-height: 320px;
	}

	.dt-hero__cta {
		font-size: var(--dt-font-size-sm) !important;
		padding: 0.75em 1.75em !important;
		width: 100%;
		justify-content: center;
	}
}

