/**
 * Páginas de Servicios - CEBEPA SAS.
 */

/* ==========================================================================
   Hero
   ========================================================================== */

.cebe-service-hero {
	padding: 88px 0 64px;
	background:
		linear-gradient(135deg, rgba(31, 51, 71, 0.98), rgba(20, 35, 51, 0.96)),
		var(--cebe-color-primary);
	color: var(--cebe-color-white);
}

.cebe-service-hero__title {
	max-width: 940px;
	margin: 0;
	color: var(--cebe-color-white);
	font-family: var(--cebe-font-title);
	font-size: clamp(2.2rem, 5vw, 4.2rem);
	font-weight: 900;
	letter-spacing: -0.05em;
	line-height: 1.02;
}

.cebe-service-hero__text {
	max-width: 780px;
	margin: 24px 0 0;
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(1rem, 2vw, 1.2rem);
	line-height: 1.7;
}

.cebe-service-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 32px;
}

/* ==========================================================================
   Página madre Servicios
   ========================================================================== */

.cebe-services-overview {
	padding: 78px 0;
	background-color: var(--cebe-color-white);
}

.cebe-services-overview__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 22px;
}

.cebe-service-overview-card {
	display: flex;
	flex-direction: column;
	padding: 28px;
	border: 1px solid var(--cebe-color-border);
	border-radius: var(--cebe-radius-lg);
	background-color: var(--cebe-color-white);
	box-shadow: var(--cebe-shadow-card);
	transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.cebe-service-overview-card:hover {
	border-color: rgba(31, 51, 71, 0.24);
	box-shadow: var(--cebe-shadow-soft);
	transform: translateY(-3px);
}

.cebe-service-overview-card__number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	margin-bottom: 20px;
	border-radius: var(--cebe-radius-sm);
	background-color: rgba(31, 51, 71, 0.08);
	color: var(--cebe-color-primary);
	font-weight: 900;
}

.cebe-service-overview-card__title {
	margin: 0;
	color: var(--cebe-color-primary);
	font-family: var(--cebe-font-title);
	font-size: 1.28rem;
	font-weight: 850;
	line-height: 1.25;
}

.cebe-service-overview-card__text {
	margin: 14px 0 0;
	color: var(--cebe-color-text);
	font-size: 0.98rem;
	line-height: 1.7;
}

.cebe-service-overview-card__link {
	display: inline-flex;
	margin-top: auto;
	padding-top: 24px;
	color: var(--cebe-color-primary);
	font-weight: 850;
	text-decoration: none;
}

.cebe-service-overview-card__link:hover,
.cebe-service-overview-card__link:focus {
	color: var(--cebe-color-accent);
	text-decoration: underline;
}

/* ==========================================================================
   Página interna de servicio
   ========================================================================== */

.cebe-service-detail {
	padding: 78px 0;
	background-color: var(--cebe-color-white);
}

.cebe-service-detail__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
	align-items: start;
}

.cebe-service-detail__content h2 {
	margin: 0 0 18px;
	color: var(--cebe-color-primary);
	font-family: var(--cebe-font-title);
	font-size: clamp(1.7rem, 3vw, 2.6rem);
	font-weight: 900;
	letter-spacing: -0.04em;
	line-height: 1.12;
}

.cebe-service-detail__content p {
	color: var(--cebe-color-text);
	font-size: 1.04rem;
	line-height: 1.75;
}

.cebe-service-list {
	display: grid;
	gap: 14px;
	margin: 28px 0 0;
	padding: 0;
	list-style: none;
}

.cebe-service-list li {
	position: relative;
	padding: 15px 18px 15px 46px;
	border: 1px solid var(--cebe-color-border);
	border-radius: var(--cebe-radius-md);
	background-color: var(--cebe-color-bg-soft);
	color: var(--cebe-color-text);
	font-weight: 750;
	line-height: 1.5;
}

.cebe-service-list li::before {
	position: absolute;
	top: 20px;
	left: 18px;
	width: 12px;
	height: 12px;
	border-radius: 999px;
	background-color: var(--cebe-color-accent);
	content: "";
}

/* ==========================================================================
   Sidebar servicios
   ========================================================================== */

.cebe-service-sidebar {
	padding: 28px;
	border: 1px solid var(--cebe-color-border);
	border-radius: var(--cebe-radius-lg);
	background-color: var(--cebe-color-bg);
	box-shadow: var(--cebe-shadow-card);
}

.cebe-service-sidebar__title {
	margin: 0 0 18px;
	color: var(--cebe-color-primary);
	font-family: var(--cebe-font-title);
	font-size: 1.2rem;
	font-weight: 850;
}

.cebe-service-sidebar__menu {
	display: grid;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.cebe-service-sidebar__menu a {
	display: block;
	padding: 12px 14px;
	border-radius: var(--cebe-radius-sm);
	background-color: var(--cebe-color-white);
	color: var(--cebe-color-primary);
	font-weight: 800;
	text-decoration: none;
}

.cebe-service-sidebar__menu a:hover,
.cebe-service-sidebar__menu a:focus,
.cebe-service-sidebar__menu a.is-active {
	background-color: var(--cebe-color-primary);
	color: var(--cebe-color-white);
}

/* ==========================================================================
   Metodología / CTA
   ========================================================================== */

.cebe-service-method {
	padding: 72px 0;
	background-color: var(--cebe-color-bg);
}

.cebe-service-method__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
}

.cebe-service-method-card {
	padding: 24px;
	border: 1px solid var(--cebe-color-border);
	border-radius: var(--cebe-radius-md);
	background-color: var(--cebe-color-white);
}

.cebe-service-method-card__number {
	margin: 0 0 10px;
	color: var(--cebe-color-accent);
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cebe-service-method-card__title {
	margin: 0;
	color: var(--cebe-color-primary);
	font-family: var(--cebe-font-title);
	font-size: 1.05rem;
	font-weight: 850;
	line-height: 1.35;
}

.cebe-service-cta {
	padding: 64px 0;
	background-color: var(--cebe-color-primary);
	color: var(--cebe-color-white);
}

.cebe-service-cta__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
	align-items: center;
}

.cebe-service-cta__title {
	margin: 0;
	color: var(--cebe-color-white);
	font-family: var(--cebe-font-title);
	font-size: clamp(1.8rem, 4vw, 3rem);
	font-weight: 900;
	letter-spacing: -0.04em;
	line-height: 1.08;
}

.cebe-service-cta__text {
	max-width: 720px;
	margin: 18px 0 0;
	color: rgba(255, 255, 255, 0.82);
	font-size: 1.05rem;
	line-height: 1.72;
}

.cebe-service-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}

.cebe-service-cta .cebe-button--primary {
	background-color: var(--cebe-color-white);
	color: var(--cebe-color-primary);
}

.cebe-service-cta .cebe-button--primary:hover,
.cebe-service-cta .cebe-button--primary:focus {
	background-color: var(--cebe-color-accent);
	color: var(--cebe-color-primary-dark);
}

.cebe-service-cta .cebe-button--secondary {
	border-color: rgba(255, 255, 255, 0.64);
	color: var(--cebe-color-white);
}

.cebe-service-cta .cebe-button--secondary:hover,
.cebe-service-cta .cebe-button--secondary:focus {
	background-color: var(--cebe-color-white);
	color: var(--cebe-color-primary);
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (min-width: 680px) {
	.cebe-services-overview__grid,
	.cebe-service-method__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 960px) {
	.cebe-services-overview__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.cebe-service-detail__grid {
		grid-template-columns: minmax(0, 1fr) 340px;
		gap: 56px;
	}

	.cebe-service-sidebar {
		position: sticky;
		top: 110px;
	}

	.cebe-service-method__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.cebe-service-cta__grid {
		grid-template-columns: minmax(0, 1fr) auto;
	}

	.cebe-service-cta__actions {
		justify-content: flex-end;
	}
}

@media (max-width: 639px) {
	.cebe-service-hero {
		padding: 56px 0 44px;
	}

	.cebe-service-hero__actions,
	.cebe-service-cta__actions,
	.cebe-service-hero__actions .cebe-button,
	.cebe-service-cta__actions .cebe-button {
		width: 100%;
	}

	.cebe-services-overview,
	.cebe-service-detail,
	.cebe-service-method {
		padding: 48px 0;
	}

	.cebe-service-overview-card,
	.cebe-service-sidebar,
	.cebe-service-method-card {
		padding: 22px;
	}

	.cebe-service-cta {
		padding: 48px 0;
	}
}