@charset "utf-8";
/*------------------------------------------------------------
	programs
------------------------------------------------------------*/
.pageTitle {
	margin-bottom: 9rem;
	background-image: url(../img/course/programs/page_photo.jpg);
}
#main .comTopBox {
	margin-bottom: 5.5rem;
}
#main .stepBox {
	position: relative;
	padding: 0 0 3.2rem 2rem;
	margin-left: auto;
	max-width: calc(50% + 57rem);
	display: flex;
	flex-wrap: wrap;
}
#main .stepBox:not(:last-of-type) .lBox:after {
	position: absolute;
	top: 20rem;
	left: 11.7rem;
	content: "";
	z-index: 1;
	width: 0.5rem;
	bottom: 0;
	background-color: #D9D9D9;
}
#main .stepBox:not(:last-of-type) .lBox::before {
	position: absolute;
	left: 10.1rem;
	content: "";
	z-index: -1;
	width: 3.7rem;
	height: 2.2rem;
	bottom: -0.2rem;
	background: url(../img/course/programs/img02.png) no-repeat center bottom / 100%;
}
#main .stepBox .lBox {
	width: 20rem;
}
#main .stepBox .lBox h4 {
	display: flex;
	align-items: center;
	text-align: center;
	justify-content: center;
	width: 20rem;
	height: 20rem;
	border-radius: 50%;
	border: 0.2rem solid #CC0012;
	background-color: #fff;
}
#main .stepBox .lBox h4 img {
	margin-top: 1.2rem;
	display: block;
	width: 11.1rem;
}
#main .stepBox .rBox {
	margin: 6.5rem 0 0 3rem;
	flex: 1;
}
#main .stepBox:last-of-type {
	padding-bottom: 0;
}
#main .stepBox:nth-last-child(2) {
	padding-bottom: 6rem;
}
#main .stepBox .rBox {
	align-items: flex-start;
}
#main .stepBox .rBox .textBox {
	margin-right: 5rem;
	width: 48rem;
}
#main .stepBox.style01 .rBox .headLine05 {
	font-size: 3.2rem;
	line-height: 1.35;
}
#main .stepBox .rBox .textBox .text {
	margin-bottom: 4rem;
	line-height: 1.75;
	text-align: justify;
}
#main .stepBox.style01 .rBox .textBox .text {
	line-height: 2;
}
#main .stepBox .rBox .textBox .ect {
	font-size: 2.2rem;
	font-weight: 700;
	color: #000;
}
#main .stepBox .rBox .textBox .ect .dot {
	font-size: 2.5rem;
	display: inline-block;
	vertical-align: -0.8rem;
}
#main .stepBox .rBox .textBox .red {
	margin-bottom: 4rem;
	font-weight: 700;
	line-height: 1.3;
	color: #CC0012;
}
#main .stepBox .rBox .photoBox {
	margin-top: 0.4rem;
	flex: 1;
}
#main .stepBox .rBox .photoBox ul {
	border-radius: 2rem 0 0 2rem;
	overflow: hidden;
}
#main .stepBox .rBox .photoBox li {
	height: 28.7rem;
}
#main .stepBox .rBox .photoBox li:not(:last-child) {
	margin-bottom: 1px;
}
#main .stepBox .rBox .photoBox img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .stepBox.style01 .rBox .photoBox li {
	height: 34rem;
}
#main .stepBox.stepBox01 .lBox h4 {
	background-color: #CC0012;
}
#main .stepBox.stepBox01 .lBox h4 img {
	margin-top: 0;
	width: 14rem;
}
#main .stepBox.stepBox01 .rBox {
	margin-top: 4rem;
}
#main .stepBox.stepBox01 .rBox .innerBox {
	position: relative;
	padding: 3rem;
	width: fit-content;
	font-size: 2.4rem;
	font-weight: 700;
	color: #000;
	line-height: 1.3;
	background-color: #eee;
	border-radius: 1rem;
}
#main .stepBox.stepBox01 .rBox .innerBox::after {
	position: absolute;
	top: 50%;
	right: 100%;
	transform: translateY(-50%);
	z-index: 1;
	width: 2rem;
	height: 2rem;
	background: url(../img/course/programs/img01.png) no-repeat left top / 100%;
	content: "";
}
@media (min-width: 1920px) {
	.pageTitle .content {
		padding: 0 22rem;
	}
}
@media all and (max-width: 896px) {
	.pageTitle {
		margin-bottom: 4.3rem;
		background-image: url(../img/course/programs/page_photo_sp.png);
	}
	#main .comTopBox {
		margin-bottom: 3.3rem;
	}
	#main .stepBox {
		padding: 0 2rem 2.2rem;
		max-width: 100%;
	}
	#main .stepBox:not(:last-of-type) .lBox:after {
		top: 8rem;
		left: 5.9rem;
		width: 0.2rem;
	}
	#main .stepBox:not(:last-of-type) .lBox::before {
		left: 5.25rem;
		width: 1.4rem;
		bottom: 0;
	}
	#main .stepBox .lBox {
		width: 8rem;
	}
	#main .stepBox .lBox h4 {
		width: 8rem;
		height: 8rem;
		border: 1px solid #CC0012;
	}
	#main .stepBox .lBox h4 img {
		margin-top: 0.4rem;
		width: 4.4rem;
		height: 2.8rem;
	}
	#main .stepBox .rBox {
		margin: 2.7rem 0 0 2rem;
		display: block;
	}
	#main .stepBox:nth-last-child(2) {
		padding-bottom: 6rem;
	}
	#main .stepBox .rBox .textBox {
		margin: 0 0 3rem;
		width: auto;
	}
	#main .stepBox .rBox .textBox .text {
		margin-bottom: 3rem;
		line-height: 2;
	}
	#main .stepBox .rBox .textBox .ect {
		font-size: 1.6rem;
	}
	#main .stepBox .rBox .textBox .ect .dot {
		font-size: 1.8rem;
		vertical-align: -0.5rem;
	}
	#main .stepBox .rBox .textBox .red {
		margin-bottom: 2.9rem;
		font-weight: 700;
		line-height: 1.3;
		color: #CC0012;
	}
	#main .stepBox .comlinkUl a {
		min-height: 4rem;
		padding: 0 2.2rem 0 2.8rem;
		font-size: 1.12rem;
	}
	#main .stepBox .comlinkUl span {
		background-size: 1rem auto;
		background-position: right 0.4rem top center;
	}
	#main .stepBox .rBox .photoBox {
		margin: 0 -2rem 0 0;
		width: auto;
	}
	#main .stepBox .rBox .photoBox li {
		height: auto !important;
	}
	#main .stepBox.stepBox01 .lBox h4 img {
		width: 5.5rem;
		height: auto;
	}
	#main .stepBox.stepBox01 {
		align-items: center;
	}
	#main .stepBox.stepBox01 .lBox {
		margin-top: -1rem;
	}
	#main .stepBox.stepBox01 .rBox {
		margin-top: 0;	
	}
	#main .stepBox.stepBox01 .rBox .innerBox {
		padding: 1.5rem;
		font-size: 1.6rem;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		min-height: 9.2rem;
	}
	#main .stepBox.stepBox01 .rBox .innerBox::after {
		position: absolute;
		top: 50%;
		right: 100%;
		transform: translateY(-50%);
		z-index: 1;
		width: 2rem;
		height: 2rem;
		background: url(../img/course/programs/img01.png) no-repeat left top / 100%;
		content: "";
	}
}