/**
 * Pàgina d'inici (Elementor #12) — redisseny visual
 */

:root {
	--cf-home-brand: #ee8516;
	--cf-home-brand-dark: #c96f10;
	--cf-home-ink: #1a2332;
	--cf-home-muted: #5c6578;
	--cf-home-surface: #f4f6f9;
	--cf-home-white: #ffffff;
	--cf-home-radius: 20px;
	--cf-home-shadow: 0 18px 48px rgba(26, 35, 50, 0.08);
}

/* Contenidor general */
.contrafoc-home-page #post-12 .entry-content {
	overflow-x: hidden;
}

.contrafoc-home-page .elementor-12 {
	--padding-top: 0;
	--padding-bottom: 0;
}

/* —— Hero —— */
.elementor-12 .elementor-element-240f590 {
	min-height: clamp(420px, 72vh, 720px) !important;
}

.elementor-12 .elementor-element-240f590::before {
	background: linear-gradient(
		135deg,
		rgba(26, 35, 50, 0.82) 0%,
		rgba(26, 35, 50, 0.45) 45%,
		rgba(238, 133, 22, 0.35) 100%
	) !important;
	opacity: 1 !important;
}

.elementor-12 .header-info h2 {
	font-family: "Roboto", system-ui, sans-serif !important;
	font-size: clamp(2rem, 5vw, 3.5rem) !important;
	font-weight: 800 !important;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	line-height: 1.1 !important;
	margin: 0 !important;
	text-shadow: 0 4px 24px rgba(0, 0, 0, 0.35);
}

.elementor-12 .header-info {
	padding: clamp(2rem, 6vw, 4rem) 1.5rem !important;
	margin: 0 !important;
	border-radius: 0 !important;
}

/* —— Nosaltres —— */
.elementor-12 .elementor-element-ccd06cc {
	background: var(--cf-home-surface) !important;
	padding: clamp(3rem, 6vw, 5rem) 0 !important;
}

.elementor-12 .elementor-element-ccd06cc > .e-con-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	gap: 2.5rem;
	align-items: stretch;
}

.elementor-12 .elementor-element-2a8d0a0 {
	min-height: 320px;
	border-radius: var(--cf-home-radius) !important;
	box-shadow: var(--cf-home-shadow);
	overflow: hidden;
	background-size: cover !important;
	background-position: center !important;
}

.elementor-12 .elementor-element-6346031 {
	background: var(--cf-home-white);
	border-radius: var(--cf-home-radius);
	box-shadow: var(--cf-home-shadow);
	padding: clamp(1.75rem, 4vw, 2.75rem) !important;
	justify-content: center;
}

.elementor-12 .elementor-element-b3705a4 .fusion-title-heading,
.elementor-12 .elementor-element-b3705a4 h2 {
	font-size: clamp(1.75rem, 3vw, 2.25rem) !important;
	font-weight: 800 !important;
	color: var(--cf-home-ink) !important;
	margin: 0 0 1.25rem !important;
	line-height: 1.2 !important;
}

.elementor-12 .elementor-element-b3705a4 .fusion-text p,
.elementor-12 .elementor-element-b3705a4 p {
	color: var(--cf-home-muted);
	font-size: 1.05rem;
	line-height: 1.75;
	margin-bottom: 1rem;
}

.elementor-12 .elementor-element-b3705a4 strong {
	color: var(--cf-home-ink);
}

.elementor-12 .elementor-element-9d5cf1d .elementor-button {
	background: var(--cf-home-brand) !important;
	border-radius: 999px !important;
	padding: 0.85em 2em !important;
	font-weight: 700;
	letter-spacing: 0.02em;
	box-shadow: 0 8px 24px rgba(238, 133, 22, 0.35);
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.elementor-12 .elementor-element-9d5cf1d .elementor-button:hover,
.elementor-12 .elementor-element-9d5cf1d .elementor-button:focus {
	background: var(--cf-home-brand-dark) !important;
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(238, 133, 22, 0.4);
}

/* —— Banda FUNDAE —— */
.elementor-12 .elementor-element-93fca5c {
	min-height: clamp(360px, 50vh, 520px) !important;
	position: relative;
}

.elementor-12 .elementor-element-93fca5c::before {
	background: linear-gradient(
		120deg,
		rgba(26, 35, 50, 0.88) 0%,
		rgba(26, 35, 50, 0.55) 55%,
		rgba(238, 133, 22, 0.25) 100%
	) !important;
	opacity: 1 !important;
}

.elementor-12 .elementor-element-b178a00 > .e-con-inner {
	max-width: 900px;
	margin: 0 auto;
	padding: 2rem 1.5rem;
}

.elementor-12 .elementor-element-93fca5c .elementor-element-7af15b5 h2,
.elementor-12 .elementor-element-93fca5c .elementor-element-7af15b5 h2 span,
.elementor-12 .elementor-element-93fca5c .elementor-element-7af15b5 p,
.elementor-12 .elementor-element-93fca5c .elementor-element-7af15b5 strong {
	color: #fff !important;
}

.elementor-12 .elementor-element-7af15b5 h2 {
	font-weight: 800 !important;
	line-height: 1.25 !important;
}

.elementor-12 .elementor-element-0732f0a .elementor-button {
	background: var(--cf-home-white) !important;
	color: var(--cf-home-brand) !important;
	border-radius: 999px !important;
	padding: 0.9em 2.25em !important;
	font-weight: 800;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.elementor-12 .elementor-element-0732f0a .elementor-button:hover,
.elementor-12 .elementor-element-0732f0a .elementor-button:focus {
	background: var(--cf-home-brand) !important;
	color: #fff !important;
}

/* —— Seccions de cursos —— */
.elementor-12 .elementor-element-e788e92,
.elementor-12 .elementor-element-3880bc6,
.elementor-12 .elementor-element-66b6c30 {
	padding: clamp(3rem, 6vw, 4.5rem) 0 !important;
}

.elementor-12 .elementor-element-e788e92 {
	background: var(--cf-home-white);
}

.elementor-12 .elementor-element-3880bc6 {
	background: var(--cf-home-surface);
}

.elementor-12 .elementor-element-66b6c30 {
	background: var(--cf-home-white);
}

.elementor-12 .elementor-element-e788e92 > .e-con-inner,
.elementor-12 .elementor-element-3880bc6 > .e-con-inner,
.elementor-12 .elementor-element-66b6c30 > .e-con-inner {
	max-width: 1240px;
	margin: 0 auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.elementor-12 .content-box-heading,
.elementor-12 .elementor-widget-text-editor h3 {
	font-size: clamp(1.35rem, 2.5vw, 1.75rem) !important;
	font-weight: 800 !important;
	color: var(--cf-home-ink) !important;
	line-height: 1.3 !important;
	margin: 0 0 0.75rem !important;
	position: relative;
	padding-left: 1rem;
	border-left: 4px solid var(--cf-home-brand);
}

.elementor-12 .elementor-widget-text-editor > .elementor-widget-container > .heading p,
.elementor-12 .elementor-widget-text-editor > .elementor-widget-container > p {
	color: var(--cf-home-muted);
	font-size: 1.05rem;
	line-height: 1.75;
	max-width: 72ch;
	margin-bottom: 2rem;
}

.elementor-12 .elementor-widget-text-editor strong {
	color: var(--cf-home-ink);
}

/* —— Sliders (només inicio) —— */
.elementor-12 .contrafoc-cursos-elementor-widget {
	margin: 0;
	padding: 0 3rem;
	position: relative;
}

.elementor-12 .contrafoc-cursos-slider-wrap {
	position: relative;
}

.elementor-12 .contrafoc-cursos-elementor-widget .contrafoc-cursos-slider {
	margin: 0 -12px;
	overflow: visible;
}

.elementor-12 .contrafoc-cursos-slide {
	padding: 0 12px;
}

.elementor-12 .contrafoc-cursos-card {
	border-radius: var(--cf-home-radius);
	box-shadow: none;
	background: transparent;
	border: none;
	transition: transform 0.35s ease;
}

.elementor-12 .contrafoc-cursos-slider .slick-list,
.elementor-12 .contrafoc-cursos-slider .slick-track,
.elementor-12 .contrafoc-cursos-slider .slick-slide,
.elementor-12 .contrafoc-cursos-slider .slick-slide > div {
	background: transparent !important;
}

.elementor-12 .contrafoc-cursos-card:hover {
	transform: translateY(-4px);
	box-shadow: none;
}

.elementor-12 .contrafoc-cursos-card-image {
	aspect-ratio: 16 / 10;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	border-radius: var(--cf-home-radius);
}

.elementor-12 .contrafoc-cursos-card-overlay {
	background: linear-gradient(
		180deg,
		transparent 35%,
		rgba(26, 35, 50, 0.15) 100%
	) !important;
}

.elementor-12 .contrafoc-cursos-card-title {
	position: relative;
	margin: 0;
	padding: 1.1rem 1.25rem 1.25rem;
	background: var(--cf-home-white);
	color: var(--cf-home-ink);
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.35;
	text-shadow: none;
	border-top: 3px solid var(--cf-home-brand);
	border-radius: 0 0 var(--cf-home-radius) var(--cf-home-radius);
	transition: color 0.2s ease, border-color 0.2s ease;
}

.elementor-12 .contrafoc-cursos-card:hover .contrafoc-cursos-card-title {
	color: var(--cf-home-brand);
}

/* Un sol curs: imatge + pastilla sense franja de foto sota el títol */
.elementor-12 .contrafoc-cursos-elementor-widget[data-per-row="1"] .slick-track,
.elementor-12 .contrafoc-cursos-elementor-widget[data-per-row="1"] .slick-slide,
.elementor-12 .contrafoc-cursos-elementor-widget[data-per-row="1"] .slick-slide > div {
	height: auto !important;
}

.elementor-12 .contrafoc-cursos-elementor-widget[data-per-row="1"] .contrafoc-cursos-card-image {
	height: auto;
	aspect-ratio: unset;
	display: block;
	overflow: hidden;
	border-radius: var(--cf-home-radius) var(--cf-home-radius) 0 0;
}

.elementor-12 .contrafoc-cursos-elementor-widget[data-per-row="1"] .contrafoc-cursos-card-bg {
	position: relative;
	inset: auto;
	width: 100%;
	height: clamp(200px, 28vw, 300px);
}

.elementor-12 .contrafoc-cursos-elementor-widget[data-per-row="1"] .contrafoc-cursos-card-overlay {
	inset: auto;
	top: 0;
	left: 0;
	right: 0;
	height: clamp(200px, 28vw, 300px);
	bottom: auto;
}

.elementor-12 .contrafoc-cursos-elementor-widget[data-per-row="1"] .contrafoc-cursos-card-title {
	border-radius: 0 0 var(--cf-home-radius) var(--cf-home-radius);
}

/* Fletxes del carrusel */
.elementor-12 .contrafoc-cursos-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	width: 48px;
	height: 48px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: var(--cf-home-white);
	color: var(--cf-home-brand);
	box-shadow: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.elementor-12 .contrafoc-cursos-arrow:hover {
	background: var(--cf-home-brand);
	color: #fff;
	transform: translateY(-50%) scale(1.05);
}

.elementor-12 .contrafoc-cursos-arrow svg {
	width: 22px;
	height: 22px;
}

.elementor-12 .contrafoc-cursos-slider-wrap .contrafoc-cursos-prev {
	left: 0;
}

.elementor-12 .contrafoc-cursos-slider-wrap .contrafoc-cursos-next {
	right: 0;
}

.elementor-12 .contrafoc-cursos-elementor-widget .slick-dots {
	margin-top: 1.75rem;
	gap: 6px;
}

.elementor-12 .contrafoc-cursos-elementor-widget .slick-dots li button {
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: #c5ccd6;
	transition: width 0.25s ease, background 0.25s ease;
}

.elementor-12 .contrafoc-cursos-elementor-widget .slick-dots li.slick-active button {
	width: 28px;
	background: var(--cf-home-brand);
}

@media (max-width: 921px) {
	.elementor-12 .contrafoc-cursos-elementor-widget {
		padding: 0 2.75rem;
	}

	.elementor-12 .contrafoc-cursos-arrow {
		width: 40px;
		height: 40px;
	}

	.elementor-12 .elementor-element-ccd06cc > .e-con-inner {
		flex-direction: column !important;
	}

	.elementor-12 .elementor-element-2a8d0a0 {
		min-height: 240px;
		width: 100% !important;
	}
}

@media (max-width: 544px) {
	.elementor-12 .contrafoc-cursos-elementor-widget {
		padding: 0 2.25rem;
	}

	.elementor-12 .contrafoc-cursos-prev {
		left: -4px;
	}

	.elementor-12 .contrafoc-cursos-next {
		right: -4px;
	}
}
