/* =============================================
   Acordeón con imagen · Frontend
   ============================================= */

.raices-acordeon {
	display: flex;
	gap: 48px;
	align-items: flex-start;
	padding: 40px 0;
}

.raices-acordeon--sin-foto .raices-acordeon__izquierda {
	max-width: 720px;
}

/* ---- Columna izquierda ---- */
.raices-acordeon__izquierda {
	flex: 1;
	min-width: 0;
}

.raices-acordeon__titulo {
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.3;
	margin: 0 0 20px;
}

.raices-acordeon__intro {
	line-height: 1.75;
	color: #555;
	margin-bottom: 32px;
}

/* ---- Acordeón ---- */
.raices-acordeon__secciones {
	border-top: 1px solid #d0d0d0;
}

.raices-acordeon__item {
	border-bottom: 1px solid #d0d0d0;
}

.raices-acordeon__btn {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 18px 0;
	background: none;
	border: none;
	cursor: pointer;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: inherit;
	text-align: left;
	line-height: 1.2;
}

.raices-acordeon__btn:hover {
	opacity: 0.7;
}

.raices-acordeon__chevron {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	transition: transform 0.25s ease;
}

.raices-acordeon__item--abierto .raices-acordeon__chevron {
	transform: rotate(180deg);
}

.raices-acordeon__contenido {
	padding: 0 0 20px;
	line-height: 1.75;
	color: #555;
	font-size: 0.95rem;
}

.raices-acordeon__contenido p:first-child { margin-top: 0; }
.raices-acordeon__contenido p:last-child  { margin-bottom: 0; }

/* ---- Columna derecha (foto) ---- */
.raices-acordeon__derecha {
	width: 42%;
	flex-shrink: 0;
	position: sticky;
	top: 40px;
}

.raices-acordeon__foto {
	width: 100%;
	height: auto;
	display: block;
	transition: opacity 0.2s ease;
}

/* ---- Responsive ---- */
@media ( max-width: 768px ) {
	.raices-acordeon {
		flex-direction: column;
		gap: 28px;
		padding: 24px 0;
	}

	.raices-acordeon__derecha {
		width: 100%;
		position: static;
		order: -1;
	}
}
