@charset "utf-8";
/*------------------------------------------------------------
	program
------------------------------------------------------------*/
.mainVisual {
	margin-bottom: 9.2rem;
	background-image: url("../img/program/main_bg.jpg");
}
@media all and (max-width: 896px) {
	.mainVisual {
		margin-bottom: 4.6rem;
		background-image: url("../img/program/main_bg_sp.jpg");
	}
	.headLine03 .en {
		font-size: 2.6rem;
		line-height: 1;
	}
}


/* boostBox */
#main .boostBox {
	margin-bottom: 9.4rem;
	position: relative;
}
#main .boostBox .bgImg {
	width: 163.6rem;
	position: absolute;
	top: -9.8rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: -1;
	margin-left: 7.4rem;
}
#main .boostBox .headLine03 {
	margin-bottom: 7.2rem;
}
#main .boostBox .headLine02 {
	margin-bottom: 8.3rem;
}
#main .boostBox .imgBox {
	display: flex;
	margin: 0 3.4rem 9.9rem;
}
#main .boostBox .imgBox .photo {
	width: 40rem;
}
#main .boostBox .imgBox .textBox {
	margin: 1rem 0 0 8.5rem;
	flex: 1;
}
#main .boostBox .imgBox .headLine02 .sml {
	letter-spacing: 0.1em;
	margin-bottom: 1.1rem;
}
#main .boostBox .imgBox .headLine02 {
	margin: 0 -2rem 2.8rem 0;
}
#main .showBox {
	padding: 6.3rem 0 5.3rem;
	background-color: #ededef;
	border: 0.1rem solid #e3e3e3;
}
#main .showBox .headLine02 {
	margin-bottom: 2.7rem;
	font-size: 2.5rem;
	text-align: center;
}
#main .showBox .imgUl {
	margin-bottom: 2.1rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1.8rem;
}
#main .showBox .imgUl li {
	width: 18rem;
	text-align: center;
}
#main .showBox .imgUl .line {
	display: inline-block;
	vertical-align: top;
	font-size: 2rem;
	border-bottom: 0.1rem solid #999999;
	position: relative;
	margin: 2rem -2rem 0;
	line-height: 1.3;
	padding-bottom: 0.2rem;
}
#main .showBox .imgUl .line::before {
	width: 1rem;
	height: 1rem;
	position: absolute;
	top: -1.1rem;
	left: 50%;
	transform: translateX(-50%);
	background: url("../img/program/icon01.png") no-repeat left top / 100% 100%;
	content: "";
}
#main .showBox .imgUl img {
	margin-bottom: 0.2rem;
}
#main .showBox .btmTxt {
	text-align: center;
	padding: 1.3rem 1.5rem 1.6rem;
	background-color: #dce5f1;
	letter-spacing: 0.13em;
}
@media all and (max-width: 896px) {
	#main .boostBox .bgImg {
		width: 60rem;
		top: 21.4rem;
		margin-left: -2.6rem;
	}
	#main .boostBox .imgBox {
		display: block;
		margin: 0 0 4.6rem;
	}
	#main .boostBox .imgBox .photo {
		width: auto;
		margin: 0 2.3rem 2.1rem 0.2rem;
	}
	#main .boostBox .imgBox .textBox {
		margin: 0;
	}
	#main .showBox {
		margin: 0 -1.8rem;
		padding: 4.6rem 2.4rem 4.9rem;
	}
	#main .showBox .headLine02 .spTxt {
		display: block;
		font-family: "Noto Sans JP", sans-serif;
		font-size: 1.75rem;
		margin-bottom: 0.7rem;
	}
	#main .showBox .imgUl {
		justify-content: space-between;
		gap: 2rem 0;
	}
	#main .showBox .imgUl li {
		width: calc(50% - 0.8rem);
		font-size: 1.37rem;
	}
	#main .showBox .imgUl .line {
		font-size: 1.67rem;
	}
	#main .boostBox .headLine02 {
		margin: 0 -1.5rem 4rem 0;
		letter-spacing: -0.05em;
		font-size: 3rem;
		line-height: 1.33;
	}
	#main .boostBox .headLine03 {
		margin-bottom: 2.8rem;
	}
	#main .boostBox .imgBox .headLine02 .sml {
		letter-spacing: 0.1em;
		margin-bottom: 0.7rem;
		font-size: 2rem;
	}
	#main .boostBox .imgBox .headLine02 {
		margin: 0 -1.5rem 2.6rem 0;
	}
	#main .boostBox .imgBox .textBox p {
		letter-spacing: 0.05em;
		margin-bottom: 2.3rem;
	}
	#main .boostBox .imgBox .textBox p:last-child {
		margin-bottom: 0;
	}
	#main .showBox .headLine02 {
		margin-bottom: 3rem;
		font-size: 2.5rem;
		letter-spacing: 0.05em;
	}
	#main .showBox .imgUl img {
		margin-bottom: 0.3rem;
		width: 100%;
	}
	#main .showBox .imgUl .line::before {
		width: 0.9rem;
		height: 0.9rem;
	}
	#main .showBox .btmTxt {
		padding: 1.2rem 1.5rem 1.5rem;
		font-size: 2rem;
		margin: 3.4rem -2.4rem 0;
		line-height: 1.3;
	}
	#main .boostBox {
		margin-bottom: 6.9rem;
	}
}



/* programBox */
#main .programBox .headLine02 {
	margin-bottom: 4.6rem;
}
#main .programBox .headLine02 .sml {
	margin-bottom: 0.8rem;
}
#main .programBox .linkUl {
	margin-bottom: 8.8rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1.7rem;
}
#main .programBox .linkUl li {
	width: 25.2rem;
}
#main .programBox .linkUl a {
	display: flex;
	width: 100%;
	height: 5.2rem;
	color: #646464;
	font-size: 2.2rem;
	align-items: center;
	justify-content: center;
	border: 0.1rem solid #646464;
	border-radius: 0.5rem;
	opacity: 0.3 !important;
}
#main .programBox .headLine03 {
	margin-bottom: 5.1rem;
}
#main .programBox .linkUl .on a {
	color: #fff;
	opacity: 1 !important;
	border-color: #7d8ca0;
	background-color: #7d8ca0;
}
@media all and (min-width: 897px) {
	#main .programBox .linkUl a:hover {
		color: #fff;
		opacity: 1 !important;
		border-color: #7d8ca0;
		background-color: #7d8ca0;
	}
}
@media all and (max-width: 896px) {
	#main .programBox .linkUl {
		display: block;
		margin-bottom: 7.1rem;
	}
	#main .programBox .linkUl li {
		margin-bottom: 2rem;
		width: auto;
	}
	#main .programBox .linkUl li:last-child {
		margin-bottom: 0;
	}
	#main .programBox .headLine02 .sml {
		margin-bottom: 1.2rem;
	}
	#main .programBox .linkUl a {
		font-size: 3rem;
		height: 6.8rem;
		border-radius: 0.5rem;
		border-width: 0.2rem;
	}
	#main .programBox .headLine02 {
		margin-bottom: 3.8rem;
	}
	#main .programBox {
		background: url("../img/program/bg06.png") no-repeat right -5rem top 20rem / 26.5rem auto;
	}
	#main .programBox .headLine03 {
		margin-bottom: 4.8rem;
	}
}


/* flexBox */
#main .flexBox {
	display: flex;
	align-items: flex-start;
}
#main .flexBox .textBox {
	flex: 1;
}
#main .flexBox .textBox p {
	margin-bottom: 0.9rem;
}
#main .flexBox .textBox p:last-child {
	margin-bottom: 0;
}
#main .flexBox .rightBox {
	width: 52.5rem;
}
#main .flexBox .headLine02 .size {
	font-size: 2rem;
	min-width: 34.1rem;
	display: inline-block;
	vertical-align: top;
	background: linear-gradient(90deg, rgba(220, 229, 241, 1) 0%, rgba(222, 231, 242, 1) 47.78%, rgba(230, 236, 245, 1) 71.17%, rgba(243, 246, 250, 1) 89.21%, rgba(255, 255, 255, 1) 100%);
	padding: 0.5rem 1rem 0.4rem;
	margin-bottom: 1.6rem;
}
#main .flexBox .headLine02 .size .text {
	font-size: 1.5rem;
}
#main .flexBox .headLine02 {
	margin-bottom: 1rem;
}
#main .flexBox .headLine02 small {
	margin-top: 1.2rem;
	padding-bottom: 1rem;
	display: block;
	font-size: 1.8rem;
}
#main .flexBox .comNotes {
	margin-top: 1.5rem;
	letter-spacing: 0.05em;
}
#main .flexBox .photoBox {
	margin-top: -0.3rem;
	width: 32rem;
}
#main .flexBox .photoBox .ttl {
	margin: 0 -2rem 0.9rem;
	font-size: 2rem;
	text-align: center;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}

@media all and (max-width: 896px) {
	#main .flexBox {
		display: block;
	}
	#main .flexBox .headLine02 .size {
		font-size: 2.25rem;
		padding: 0.5rem 1.5rem 0.8rem;
		margin-bottom: 1.6rem;
		letter-spacing: 0;
	}
	#main .flexBox .headLine02 .size sup {
		font-size: 1.3rem !important;
  		margin-top: 0.4rem;
	}
	#main .flexBox .headLine02 .size .letter {
		letter-spacing: -0.05em;
	}
	#main .flexBox .headLine02 {
		margin-bottom: 1.8rem;
		font-size: 3rem;
	}
	#main .flexBox .textBox p {
		margin-bottom: 1.3rem;
		letter-spacing: 0.05em;
	}
	#main .flexBox .headLine02 small {
		margin-top: 0.5rem;
		padding-bottom: 0;
		font-size: 1.8rem;
		letter-spacing: -0.05em;
	}
	#main .flexBox .photo {
		margin: -1.9rem -1.8rem 4.1rem;
		text-align: center;
	}
	#main .flexBox .photo img {
		width: 100%;
	}
	#main .flexBox .photoBox {
		margin-top: 4rem;
		width: auto;
	}
	#main .flexBox .photoBox .ttl {
		margin: 0 -1.5rem 1.3rem;
	}
	#main .flexBox .photoBox .image img {
		width: 100%;
	}
}

/* box01 */
#main .box01 {
	margin-bottom: 9.9rem;
}
#main .box01 .flexBox .rightBox {
	width: 52.5rem;
	background-color: #f2f2f2;
	padding: 3.5rem 5.1rem 4rem;
}
#main .box01 .flexBox .rightBox .ttl {
	font-size: 1.87rem;
	margin-bottom: 1.2rem;
}
#main .box01 .listUl {
	margin: 0 -5rem;
	display: flex;
	justify-content: center;
	font-size: 1.5rem;
	gap: 3.5rem;
}
#main .box01 .listUl li {
	width: 13.5rem;
	text-align: center;
}
#main .box01 .listUl p {
	margin: 0 -1.5rem;
	line-height: 1.15;
}
#main .box01 .listUl img {
	margin-bottom: 0.2rem;
}
@media all and (max-width: 896px) {
	#main .box01 .flexBox .rightBox {
		width: auto;
		padding: 1.7rem 2rem 2.2rem;
		margin-bottom: 3rem;
	}
	#main .box01 .flexBox .rightBox .ttl {
		font-size: 1.38rem;
		margin-bottom: 0.6rem;
	}
	#main .box01 .listUl {
		font-size: 1.1rem;
		gap: 1.4rem;
	}
	#main .box01 .listUl li {
		width: 10rem;
	}
	#main .box01 {
		margin-bottom: 4.5rem;
	}
	
}


/* useBox */
#main .useBox {
	padding: 10rem 0 9.6rem;
	background: url("../img/program/bg03.png") repeat-x left top / 0.5rem auto;
}
#main .useBox .imgBox {
	margin-bottom: 5.8rem;
	display: flex;
	position: relative;
}
#main .useBox .imgBox .enImg {
	width: 19.7rem;
	position: absolute;
	top: -5rem;
	right: -10.8rem;
}
#main .useBox .imgBox .photo {
	width: 53.1rem;
	position: absolute;
	top: 0.4rem;
	right: 2.4rem;
	z-index: 5;
}
#main .useBox .imgBox .textBox {
	padding: 3.2rem 8rem 6.2rem;
	width: 50rem;
	background-color: #fff;
	border: 0.1rem solid #e3e3e3;
	position: relative;
	z-index: 10;
}
#main .useBox .imgBox .headLine02 {
	letter-spacing: 0;
	margin: 0 -3rem 1.3rem 0;
}
#main .useBox .imgBox .headLine02 sup {
	font-size: 1.8rem !important;
	margin: 0.5rem 0 0 0.2rem;
}
#main .useBox .imgBox .headLine02 .ttl {
	margin: 0 0 1.8rem -0.8rem;
	display: block;
	font-size: 5.5rem;
	line-height: 1;
}
#main .useBox .imgBox .headLine02 .ttl .big {
	font-size: 9rem;
}
#main .useBox .imgBox .headLine02 small {
	margin-top: 0.9rem;
	font-size: 2.2rem;
	display: inline-block;
	vertical-align: top;
	border-top: 0.1rem solid #e3e3e3;
	border-bottom: 0.1rem solid #e3e3e3;
	padding: 0.5rem 0 0.6rem;
}
#main .useBox .imgBox .headLine02 small sup {
	font-size: 1.2rem !important;
	margin: 0.3rem 0.5rem 0;
}
#main .useBox .imgBox .comNotes {
	margin-top: 1.7rem;
	color: #b6b6b6 !important;
	letter-spacing: 0;
}
#main .jsSwiper {
	margin: 0 -2.5rem;
}
#main .stepUl {
	/* margin: 0 -2.5rem; */
	/* display: flex; */
}
#main .jsSwiper02 .stepUl .slick-slide > div {
	width: 35rem;
	padding: 0 2.5rem;
}
#main .stepUl > li {
	width: 35rem;
	padding: 0 2.5rem;
	flex-shrink: 0;
}
#main .stepUl .headLine02 {
	font-size: 2.8rem;
	margin-bottom: 1.2rem;
}
#main .stepUl .image {
	margin-bottom: 1.5rem;
	position: relative;
}
#main .stepUl img {
	width: 100%;
}
#main .stepUl p {
	letter-spacing: 0;
}
#main .stepUl .comNotes {
	margin-top: 0.8rem;
	letter-spacing: 0.05em;
}
#main .stepUl .proImg {
	width: 13rem;
	position: absolute;
	left: -2.9rem;
	bottom: -1.1rem;
}
#main .stepUl .item03 .proImg {
	width: 3.5rem;
	left: -0.1rem;
	bottom: -0.3rem;
}
@media all and (max-width: 896px) {
	#main .useBox {
		padding: 3.5rem 0 14.3rem;
		background: url("../img/program/bg03_sp.png") repeat-x left top / 0.5rem auto;
	}
	#main .useBox .content {
		margin: 0 1.7rem;
	}
	#main .useBox .imgBox {
		display: block;
		margin-bottom: -3.3rem;
	}
	#main .useBox .imgBox .textBox {
		width: auto;
		padding: 0.6rem 2rem 3.5rem;
		z-index: inherit;
	}
	#main .useBox .imgBox .textBox * {
		position: relative;
		z-index: 20;
	}
	#main .useBox .imgBox .photo {
		width: auto;
		position: relative !important;
		top: auto !important;
		right: auto !important;
		margin: -7.2rem -1.7rem 0;
		z-index: 15;
		text-align: center;
	}
	#main .useBox .imgBox .photo img {
		width: 100%;
		max-width: 40rem;
	}
	#main .useBox .imgBox .enImg {
		width: 9.8rem;
		top: auto !important;
		right: -1.7rem;
		bottom: 4.4rem;
	}
	#main .useBox .imgBox .headLine02 {
		letter-spacing: -0.05em;
		margin: 0 -1rem 0.6rem 0;
	}
	#main .useBox .imgBox .headLine02 .ttl {
		font-size: 3.5rem;
		margin-bottom: 0;
	}
	#main .useBox .imgBox .headLine02 .ttl .big {
		font-size: 7.5rem;
	}
	#main .useBox .imgBox .headLine02 small {
		font-size: 2.3rem;
		margin-top: 0.3rem;
		padding: 0.2rem 0 0.2rem;
	}
	#main .useBox .imgBox .headLine02 sup {
		font-size: 1.5rem !important;
		margin: 0.5rem 0 0 0.4rem;
	}
	#main .useBox .imgBox .textBox p {
		letter-spacing: 0.05em;
	}
	#main .useBox .imgBox .comNotes {
		margin-top: 1.2rem;
	}
	#main .stepUl > li {
		width: 30.7rem;
		padding: 0 2.2rem;
		font-size: 1.4rem;
	}
	#main .jsSwiper {
		margin: 0 -2.2rem;
	}
	#main .jsSwiper02 .stepUl .slick-slide > div {
		width: 30.7rem;
		padding: 0 2.2rem;
	}
	#main .stepUl p {
		line-height: 1.62;
	}
	#main .stepUl .headLine02 {
		font-size: 2.3rem;
		margin-bottom: 0.6rem;
	}
	#main .stepUl .image {
		margin-bottom: 1.2rem;
	}
	#main .stepUl .comNotes {
		margin-top: 0.8rem;
		letter-spacing: 0.05em;
		font-size: 0.96rem !important;
	}
	#main .stepUl sup {
		font-size: 0.8rem !important;
	}
	#main .stepUl .comNotes li {
		margin-bottom: 0.8rem;
	}
	#main .stepUl .proImg {
		width: 11.3rem;
		left: -3.3rem;
		bottom: -0.6rem;
	}
	#main .stepUl .item03 .proImg {
		width: 3.1rem;
	}
}

/* howBox */
#main .howBox {
	margin-top: 4.5rem;
	padding: 5rem 5.8rem 6rem;
	background-color: #ededef;
	border: 0.1rem solid #e3e3e3;
	position: relative;
}
#main .howBox::before {
	width: 2rem;
	height: 2.1rem;
	position: absolute;
	top: -2.1rem;
	left: 50%;
	transform: translateX(-50%);
	background: url("../img/program/icon02.png") no-repeat left top / 100% 100%;
	content: "";
}
#main .howBox .imgUl {
	display: flex;
	flex-wrap: wrap;
	text-align: center;
	gap: 2.5rem;
}
#main .howBox .imgUl .inner {
	width: 12.9rem;
}
#main .howBox .imgUl img {
	width: 100%;
}
#main .howBox .imgUl > li {
	position: relative;
}
#main .howBox .imgUl > li::before {
	width: 1rem;
	height: 1rem;
	position: absolute;
	top: 5.3rem;
	right: -1.8rem;
	background: url("../img/program/icon01.png") no-repeat left top / 100% 100%;
	transform: rotate(-90deg);
	content: "";
}
#main .howBox .imgUl > li:last-child::before {
	display: none;
}
#main .howBox .imgUl p {
	margin-top: 0.7rem;
	line-height: 1.15;
}
#main .howBox .imgUl .innerUl {
	display: flex;
	gap: 0.5rem;
}
#main .howBox .headLine02 {
	margin: 0;
	font-size: 2rem;
	text-align: center;
}
#main .howBox .comNotes {
	margin: -1.7rem 0.3rem 2.6rem 0;
	color: #646464 !important;
	text-align: right;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	#main .howBox {
		margin: 4.4rem -1.8rem 0;
		padding: 0;
		border: 0.1rem solid #e3e3e3;
	}
	#main .howBox .headLine02 {
		font-size: 1.8rem;
	}
	#main .howBox::before {
		display: none;
	}
	#main .howBox .comNotes {
		margin: 0.4rem 0 0 0;
		text-align: center;
		font-size: 1rem !important;
	}
	#main .howBox .imgUl {
		display: block;
		padding: 0 4.3rem 5rem;
		font-size: 1.44rem;
		display: none;
	}
	#main .howBox .imgUl .inner {
		padding-left: 2rem;
		width: auto;
		display: flex;
		align-items: center;
	}
	#main .howBox .imgUl .txt {
		flex: 1;
		margin: -0.3rem 0 0 2.1rem;
	}
	#main .howBox .imgUl .image {
		width: 40%;
	}
	#main .howBox .imgUl .innerUl {
		display: block;
	}
	#main .howBox .imgUl .innerUl li {
		margin-bottom: 1rem;
		position: relative;
	}
	#main .howBox .imgUl .innerUl li:last-child {
		margin-bottom: 0;
	}
	#main .howBox .imgUl .innerUl li::before {
		width: calc(60% - 3rem);
		height: 0.9rem;
		top: auto;
		right: 0;
		transform: rotate(0);
		bottom: -1rem;
		background: url("../img/program/icon01.png") no-repeat top center / auto 100%;
		position: absolute;
		content: "";
	}
	#main .howBox .imgUl .innerUl li:last-child:before {
		display: none;
	}
	#main .howBox .imgUl > li {
		position: relative;
		margin-bottom: 0.9rem;
	}
	#main .howBox .imgUl > li:last-child {
		margin-bottom: 0;
	}
	#main .howBox .imgUl > li::before {
		width: calc(60% - 3rem);
		height: 0.9rem;
		top: auto;
		right: 0;
		transform: rotate(0);
		bottom: -1rem;
		background-size: auto 100%;
		background-position: top center;
	}
	#main .howBox .checkBox {
		padding: 0 5rem 0 4rem;
		height: 8.4rem;
		display: flex;
		align-items: center;
		justify-content: center;
		position: relative;
		cursor: pointer;
	}
	#main .howBox .checkBox:after,
	#main .howBox .checkBox::before {
		width: 2rem;
		height: 0.1rem;
		position: absolute;
		top: 50%;
		right: 1.7rem;
		background-color: #646464;
		content: "";
	}
	#main .howBox .checkBox:after {
		transform: rotate(90deg);
	}
	#main .howBox .checkBox.on:after {
		display: none;
	}
}

/* slickBox */
#main .slickBox {
	position: relative;
	z-index: 30;
}
#main .slickBox .comArrow li {
	width: 4.7rem;
	height: 4.7rem;
	position: absolute;
	top: 10.7rem;
	left: 0.4rem;
	background-color: #fff;
	z-index: 100;
}
#main .slickBox .comArrow li.swiper-button-disabled {
	display: none;
}
#main .slickBox .comArrow .next {
	left: auto;
	right: 0.4rem;
}
#main .slickBox .comArrow img {
	width: 1.7rem;
}
@media all and (min-width: 897px) {
	#main .slickBox::before,
	#main .slickBox::after {
		width: 8.8rem;
		height: 100%;
		position: absolute;
		top: 0;
		right: 0;
		background : linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
		content: "";
		z-index: 10;
	}
	#main .slickBox::before {
		left: 0;
		right: auto;
		transform: rotate(180deg);
	}
}
@media all and (max-width: 896px) {
	#main .slickBox .comArrow li {
		width: 4rem;
		height: 4rem;
		top: 9.3rem;
		left: 1.5rem;
	}
	#main .slickBox .comArrow .next {
		left: auto;
		right: 1.5rem;
	}
	#main .slickBox .comArrow img {
		width: 1.4rem;
	}
}

/* accordion */
#main .accordionTtl {
	padding: 0.6rem 0 1.2rem;
	font-size: 4.1rem;
	font-weight: 400;
	border-top: 0.1rem solid #e3e3e3;
	border-bottom: 0.1rem solid #e3e3e3;
	line-height: 1;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
	cursor: pointer;
}
#main .accordionTtl span {
	display: block;
	margin: 0 auto;
	max-width: 100rem;
	position: relative;
}
#main .accordionTtl span::after {
	margin-top: -0.6rem;
	width: 1.7rem;
	height: 1.7rem;
	position: absolute;
	top: 50%;
	right: 0;
	background: url("../img/program/icon03.png") no-repeat left top / 100% 100%;
	content: "";
}
#main .accordionTtl.on span::after {
	transform: rotate(90deg);
}
#main .accordionConts {
	display: none;
}
#main .accordionBox + .accordionBox {
	margin-top: -0.1rem;
}
@media all and (min-width: 897px) {
	#main .accordionTtl:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#main .accordionTtl {
		padding: 0.6rem 3.1rem 1.1rem;
		font-size: 3.6rem;
		letter-spacing: 0.05em;
	}
	#main .accordionTtl span::after {
		margin-top: -0.5rem;
		width: 1.5rem;
		height: 1.5rem;
		right: -1.3rem;
	}
}


/* days23  */
#main .days23 .useBox {
	padding: 10.7rem 0;
}
#main .days23 .useBox .imgBox .textBox {
	padding: 3.2rem 6.2rem 6.1rem 7.1rem;
}
#main .days23 .useBox .imgBox .photo {
	width: 57.8rem;
	top: -1.2rem;
	right: -1rem;
}
#main .days23 .stepUl .item02 .proImg {
	width: 3.1rem;
	left: -0.1rem;
	bottom: -0.5rem;
}
#main .days23 .stepUl .item03 .proImg {
	width: 2.9rem;
}
#main .days23 .stepUl .item04 .proImg {
	width: 5.7rem;
	left: 0;
	bottom: -0.4rem;
}
#main .days23 .slickBox::before,
#main .days23 .slickBox::after {
	display: none;
}
@media all and (max-width: 896px) {
	#main .days23 .useBox .imgBox .photo {
		width: auto;
		margin: -1.4rem -1.7rem -7.7rem;
	}
	#main .days23 .useBox {
		padding: 3.3rem 0;
	}
	#main .days23 .useBox .imgBox .textBox {
		padding: 0.6rem 2rem 2.5rem;
	}
	#main .useBox .imgBox .headLine02 .ttl {
		font-size: 4.5rem;
	}
}

/* aBox */
#main .aBox .slickBox::before,
#main .aBox .slickBox::after {
	width: 22.6rem;
	pointer-events: none;
}
#main .aBox .accordionTtl {
	font-size: 0;
	padding: 1.4rem 0 1.6rem;
}
#main .aBox .accordionTtl img {
	width: 6.3rem;
}
#main .aBox .useBox {
	padding: 7.8rem 0 0;
}
#main .aBox .useBox .imgBox .headLine02 .ttl {
	margin: 0 0 1.6rem 0.8rem;
}
#main .aBox .useBox .imgBox .headLine02 img {
	width: 10.9rem;
}
#main .aBox .useBox .imgBox .enImg {
	top: -7.9rem;
}
#main .aBox .useBox .imgBox .textBox {
	padding: 7.9rem 6.2rem 7rem 7.1rem;
}
#main .aBox .useBox .imgBox .photo {
	width: 59.6rem;
	top: 0.2rem;
	right: -1.5rem;
}
#main .aBox .useBox .imgBox {
	margin-bottom: 6.3rem;
}
#main .aBox .stepUl .headLine02 {
	font-size: 2.5rem;
}
#main .aBox .stepUl .item02 .proImg {
	width: 3rem;
	left: -0.1rem;
	bottom: -0.5rem;
}
#main .aBox .stepUl .item03 .proImg {
	width: 2.8rem;
}
#main .aBox .stepUl .item04 .proImg {
	width: 5.7rem;
	left: 0;
	bottom: -0.4rem;
}
#main .aBox .stepUl .item07 .proImg {
	width: 9.5rem;
	left: -2.8rem;
	bottom: -0.5rem;
}
@media all and (min-width: 897px) {
	#main .aBox .slickBox .comArrow li {
		top: 10.3rem;
		left: 50%;
		transform: translateX(-50%);
		margin-left: -35rem;
	}
	#main .aBox .slickBox .comArrow .next {
		right: auto;
		transform: translateX(-50%) rotate(180deg);
		margin-left: 35rem;
	}
}
@media all and (max-width: 896px) {
	#main .aBox .accordionTtl {
		padding: 1.4rem 3.1rem 1.4rem;
	}
	#main .aBox .useBox .imgBox .photo {
		width: auto;
	}
	#main .aBox .accordionTtl img {
		width: 5.6rem;
	}
	#main .aBox .useBox {
		padding: 3.4rem 0 0;
	}
	#main .aBox .useBox .imgBox .textBox {
		padding: 3.3rem 2rem 3.5rem;
	}
	#main .aBox .useBox .imgBox .headLine02 img {
		width: 7.8rem;
	}
	#main .aBox .useBox .imgBox .headLine02 .ttl {
		margin: 0 0 0.3rem 0.3rem;
	}
	#main .aBox .useBox .imgBox {
		margin-bottom: -7.1rem;
	}
	#main .aBox .stepUl .headLine02 {
		font-size: 2rem;
	}
	#main .aBox .stepUl .item02 .proImg {
		width: 2.7rem;
		left: -0.5rem;
		bottom: -0.2rem;
	}
	#main .aBox .stepUl .item03 .proImg {
		width: 2.5rem;
	}
	#main .aBox .stepUl .item04 .proImg {
		width: 5rem; 
		left: -0.2rem;
		bottom: -0.4rem;
	}
	#main .aBox .stepUl .item07 .proImg {
		width: 8.6rem;
		left: -2.5rem;
		bottom: -0.6rem;
	}
}

/* box02 */
#main .box02 {
	margin-bottom: 7.8rem;
	padding-top: 7.8rem;
}

@media all and (min-width: 897px) {
	#main .box02 .flexBox {
		background: url("../img/program/bg04.png") no-repeat center center / 58rem auto;
	}
}
@media all and (max-width: 896px) {
	#main .box02 .flexBox .textBox {
		font-size: 1.5rem;
	}
	#main .box02 .flexBox .textBox p {
		line-height: 1.5;
	}
	#main .box02 {
		margin-bottom: 6.7rem;
		padding-top: 3.4rem;
	}
}

/* box03 */
@media all and (min-width: 897px) {
	#main .box03 .flexBox {
		background: url("../img/program/bg05.png") no-repeat center center / 58rem auto;
	}
}
@media all and (max-width: 896px) {
	#main .box03 .flexBox .textBox {
		font-size: 1.5rem;
	}
	#main .box03 .flexBox .textBox p {
		line-height: 1.5;
	}
	#main .box03 .flexBox .photoBox {
		margin-bottom: 1.7rem;
	}
	#main .box03 .comHow {
		margin-top: 2.9rem;
	}
}


/* days07  */
#main .days07 .stepUl .item04 .proImg {
	width: 3.9rem;
	left: -2.1rem;
	bottom: -0.3rem;
}
@media all and (min-width: 897px) {
	#main .days07 .slickBox::before,
	#main .days07 .slickBox::after {
		display: none;
	}
}


.jsSwiper {
	overflow: visible;
}


.content02 {
    max-width: 70rem;
}
.jsSwiper02 .slick-list {
    overflow: visible;
}