@charset "UTF-8";

body{
	overflow-x: hidden;
}
/* ++++#main-visual++++ */
.main-visual-outer{
	//display: none;
}
#main-visual{
/*
	height: 400vh;
*/
	height: calc(64.2rem * 3);
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	z-index: 1;
	position: relative;
}


/* ++++作業の邪魔なのでアニメーションを一時停止++++ */


#main-visual .content{
	position: fixed;
	left: 0;
	right: 0;
	top: 12rem;
	height: 70rem;
	z-index: 9;
	padding-inline: 2.5vw;
}


/* +++.one+++ */
.one{
	opacity: 0;
	transform: scale(.9);
	transition: .1s transform ease-in, .1s opacity ease-in;
	padding-top: 3.6rem;

}
.catch-copy{
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}
.bg-blue{
	color: #fff !important;
	background: #00a0e9;
	font-size: 2.8rem;
}
.one h2 span{
	padding: .3em .75em;
	display: block;
	margin-bottom: .25em;
}
.price-area{
	margin-top: 2rem;
}
.price-area dt{
	font-size: 2.4rem;
	line-height: 1.5;
	padding-right: 1em;
}
.price-area dd{
	font-size: 9rem;
	line-height: 1;
}
.price-area dd span{
	font-size: 75%;
}
.feature-text-area{
	border: 1px solid #f68026;
	background: rgba(255,255,255,.75);
	width: 58rem;
	margin-top: 2.4rem;
}
.feature-text-area h3{
	color: #fff;
	background: #f68026;
	font-size: 2.2rem;
	width: 100%;
	height: 2.3em;
	line-height: 1;
}
.feature-text-area ul{
	padding: 1em;
}
.feature-text-area li{
	font-size: 1.6rem;
	line-height: 1.75;
	margin-bottom: .5em;
	text-indent: -1.25em;
	padding-left: 1.25em;
	font-weight: 500;
}
.feature-text-area li:before{
	content: "★ ";
	display: inline;
	color: #fcd001;
}
#main-visual .caption{
	font-size: 1.4rem;
	margin-top: 1em;
}
.text-content{
	position: relative;
	z-index: 9;
	padding-top: 2.4rem;
}
.mv-pic{
	position: absolute;
	right: 0;
	top: 0;
	z-index: 1;
}
/* +++.two+++ */
.two{
	padding-top: 3.6rem;
}
.three{
	padding-top: 1.8rem;
}
.two.no-active h2,
.two.no-active p,
.two.no-active .pic-area .pic,
.two.no-active .pic-area:before,
.two.no-active .pic-area:after{
	opacity: 0;
	visibility: hidden;
	transition: .15s all ease-in;
}
.two .catch-copy{
	align-items: center !important;
}
.two .catch-copy span{
	font-size: 2.2rem;
	margin-bottom: .5em;
	padding: .3em .75em;
}
.two mark{
	background: none;
	font-weight: 900;
	color: #fc5151;
}
.two h2{
	margin-block: 2.4rem;
	position: relative;
	z-index: 99;
	line-height: 1.5;
	text-align: center;
}
.two .caption{
	text-align: center !important;
}
.two h2,
.three h2,
.two .catch-copy{
	transform: scale(.95);
	transition: .05s transform ease-in, .05s opacity ease-in;
	transition-delay: .6s;
	opacity: 0;
}
.loaded.count-comp .two.active h2,
.loaded.count-comp .three.active h2,
.two .catch-copy{
	opacity: 1;
	transform: scale(1);
	visibility: visible;
}
.two h2 img,
.three h2 img{
	display: block;
	width: 100%;
}

.two p.medium{
	text-align: center;
	font-size: min(2rem, 2.604vh);
	line-height: 2;
	letter-spacing: .05em;
	margin-bottom: min(2.5rem, 3.255vh);
	position: relative;
	z-index: 9;
}
.two p.medium,
.three p.bold{
	transform: translateY(min(2rem, 2.604vh));
	transition: .1s transform ease-in, .1s opacity ease-in;
	transition-delay: .65s;
}

.loaded.count-comp .two.active p.medium,
.loaded.count-comp .three.active p.bold{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
}
.two p.ekichika{
	width: min(35.5rem, 46.223vh);
	margin-top: min(1rem, 1.302vh);
	transition: .2s opacity ease-in;
	transition-delay: .8s;
}
.loaded.count-comp .two.active p.ekichika{
	opacity: 1;
	visibility: visible;
}

.two .pic-area{
	position: absolute;
	top: 3.6rem;
}
.two .pic01{
/*
	width: min(13.6rem, 17.708vh);
*/
	width: 16rem;
	left: 0;
}
.two .pic02{
/*
	width: min(10.1rem, 13.151vh);
*/
	width: 12rem;
	right: 0;
}
.two .pic-area .pic{
	position: relative;
	z-index: 9;
}
.two .pic-area .pic,
.three li{
	transform: translateY(1.5rem);
	transition: .15s opacity ease-in, .15s transform ease-in;
}
.three .catch-copy02{
	position: relative;
	left: auto;
	right: auto;
	top: auto;
	bottom: auto;
	width: 100%;
	font-size: 1.7rem;
}
.three li{
	visibility: hidden;
	opacity: 1;
}
.two .pic-area.pic01:before{
	content: "";
	display: block;
	width: min(27.2rem, 35.416vh);
	height: min(21.9rem, 28.515vh);
	position: absolute;
	top: min(5.4rem, 7.031vh);
	left: max(-8.5rem, -11.067vh);
	background: url(../images/mv-sec02-line01.png) no-repeat;
	background-size: 100% auto;
	z-index: 1;

	transform: scale(0);
	transform-origin: right top;
	transition: .15s transform ease-in, .15s opacity ease-in;
	transition-delay: 1s;
}
.two .pic-area.pic02:before{
	content: "";
	display: block;
	width: min(24.6rem, 32.031vh);
	height: min(20.4rem, 26.562vh);
	position: absolute;
	top: min(3.6rem, 4.687vh);
	right: max(-6rem, -7.812vh);
	background: url(../images/mv-sec02-line02.png) no-repeat;
	background-size: 100% auto;
	z-index: 1;

	transform: scale(0);
	transform-origin: right top;
	transition: .15s transform ease-in, .15s opacity ease-in;
	transition-delay: 1.2s;
}
.two .pic-area:after{
	content: "";
	display: block;
	width: min(12.5rem, 16.276vh);
	height: min(3.6rem, 4.687vh);
	border-radius: 50%;
	position: absolute;
	bottom:max( -.6rem, -.781vh);
	left: 0;
	right: 0;
	margin: auto;
	background: linear-gradient(90deg, #fbac8c, #ff8b88);

	transtion: .3s all ease-in;
	transform: scale(0);
	transition: .2s transform ease-in, .3s opacity ease-in;
}
.two .pic01:after{
	transition-delay: 1s;
}
.two .pic02:after{
/*
	right: max(-1rem, -1.302vh);
*/
	right: 0;
	left: auto;
	background: linear-gradient(-90deg, #79b2dc, #73d4da);

	transition-delay: 1.1s;
}

.loaded.count-comp .two.active .pic01 .pic,
.loaded.count-comp .three.active li:nth-of-type(1){
	transition-delay: 1.2s;
}
.loaded.count-comp .two.active .pic02 .pic,
.loaded.count-comp .three.active li:nth-of-type(2){
	transition-delay: 1.4s;
}
.loaded.count-comp .two.active .pic-area .pic,
.loaded.count-comp .three.active li{
	transform: translateY(0);
	visibility: visible;
	opacity: 1;
}

.loaded.count-comp .two.active .pic01:before,
.loaded.count-comp .two.active .pic02:before{
	visibility: visible;
	opacity: 1;
	transform: scaleX(1);
}
.loaded.count-comp .two.active .pic01:after,
.loaded.count-comp .two.active .pic02:after{
	visibility: visible;
	opacity: 1;
	transform: scale(1);
}
/* +++.three+++ */
.three{
	text-align: center;
}
.three h2{
	text-align: center;
	line-height: 1.75;
	font-size: 2.6rem;
	position: relative;
	z-index: 9;
	visibility: hidden;
	opacity: 0;
}
.three p.bold{
	font-size: 1.7rem;
	line-height: 1.75;
	margin-block: 2rem 2.4rem;
	position: relative;
	z-index: 9;
	visibility: hidden;
	opacity: 0;
}
.three mark{
	background: none;
	color: #fc5151;
}
.three ul{
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 9;
	max-width: 90rem;
	margin-inline: auto;
	
}
.three li{
	width: calc(50% - 3.6rem);
	visibility: hidden;
	opacity: 0;
	border: 1px solid #f68026;
	background: #fff;
}
.three li h3{
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.8rem;
	height: 3em;
	width: 100%;
	background: #f68026;
	color: #fff;
	position: relative;
	z-index: 9;
}
.three li:nth-of-type(2){
	border-color: #00a0e9;
}
.three li:nth-of-type(2) h3{
	background: #00a0e9;
}
.three li p{
	padding: 1em;
	line-height: 1.75;
	text-align: left !important;
	font-size: 95%;
}


/* +++.pic-list+++ */
.pic-list{
	position: fixed;
	left: 0;
	right: 0;
	top: calc(8rem + 3.385vh);
	margin: auto;
	max-width: calc(100rem + 5vw);
	height: min(66.3rem, calc(100vh - 8rem - 3.385vh));
	height: min(86.328vh, calc(100vh - 8rem - 3.385vh));
	z-index: 9;
}
.pic-list li{
	max-width: 15.7rem;
	max-height: 15.7rem;

	width: 20.442vh;
	height: 20.442vh;
	position: absolute;
	transform: scale(.5) rotate(-45deg);
	opacity: 0;

	transition: .12s transform ease-in, .06s opacity ease-in;
	transition-delay: .5s;
}
.pic-list li:nth-of-type(2),
.pic-list li:nth-of-type(3){
	transform: scale(0) rotate(45deg);
}
.loaded.count-comp .pic-list li,
.loaded.count-comp .one{
	transform: scale(1) rotate(0deg);
	opacity: 1;
	visibility: visible;
}
.loaded.count-comp .one.no-active{
	opacity: 0;
	transform: translateY(-5rem);
	visibility: hidden;
	transition: .2s all ease-in;
}
.pic-list li:before{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 1;
	transform: rotate(12.5deg);
	background: linear-gradient(90deg, #ffad8c, #ff6884);
/*
	border-radius: 2rem;
*/
	border-radius: 12.738%;
}
.pic-list li:nth-of-type(2):before{
	transform: rotate(-12.5deg);
	background: linear-gradient(90deg, #7eebf1, #75c1f7);
}
.pic-list li:nth-of-type(3):before{
	transform: rotate(-12.5deg);
	background: linear-gradient(90deg, #f9c2e2, #c0c1ff);
}
.pic-list li:nth-of-type(4):before{
	background: linear-gradient(90deg, #fbd192, #fcb458);
}

.pic-list li:nth-of-type(2n+1){
	left: 2.5vw;
}
.pic-list li:nth-of-type(2n){
	right: 2.5vw;
}
.pic-list li:nth-of-type(1),
.pic-list li:nth-of-type(2){
	top: 0rem;
}
.pic-list li:nth-of-type(3),
.pic-list li:nth-of-type(4){
	bottom: 0rem;
}


.pic-list .pic-slide{
	border-radius: 12.738%;
	border: .1rem solid #333;
	overflow: hidden;
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 9;
	
	animation-name: vibration;
	animation-duration: 1s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
	animation-direction: alternate;
}
.pic-list li:nth-of-type(2) .pic-slide,
.pic-list li:nth-of-type(3) .pic-slide{
	animation-name: vibration2;
}

@keyframes vibration{
	0%{
		transform: rotate(0);
	}
	10%{
		transform: rotate(-12.5deg);
	}
	20%{
		transform: rotate(0deg);
	}
}
@keyframes vibration2{
	0%{
		transform: rotate(0);
	}
	10%{
		transform: rotate(12.5deg);
	}
	20%{
		transform: rotate(0deg);
	}
}



/* +++++++++main-visual (SP)++++++++++ */
@media screen and (max-width: 768px){
	#main-visual{
		height: calc((100vh - 7rem) * 3);

	}

	#main-visual .content{
		position: fixed;
		left: 0;
		right: 0;
		top: 7rem;
		height: calc(100vh - 7rem);
		min-height: calc(100vw / 9 * 16);
		padding-inline: 1.5rem;
	}


/* +++.one+++ */
	.one{
		padding-top: 0;
	}
	.bg-blue{
		font-size: 1.7rem;
	}
	.one h2 span{
		padding: .3em .25em;
	}
	.price-area{
		margin-top: 5rem;
		display: block;
	}
	.price-area dt{
		font-size: 1.7rem;
		padding-right: 0;
		margin-bottom: .5rem;
	}
	.price-area dd{
		font-size: 6rem;
	}

	.feature-text-area{
		width: 100%;
		margin-top: 6.4rem;
	}
	.feature-text-area h3{
		font-size: 1.7rem;
		height: 2em;
	}

	.feature-text-area li{
		font-size: 1.5rem;
		line-height: 1.5;
	}

	#main-visual .caption{
		font-size: 1.2rem;
		line-height: 1.5;
	}
.text-content{
	position: relative;
	z-index: 9;
	padding-top: 2.4rem;
}
	.mv-pic{
		top: 10rem;
	}
/* +++.two+++ */
	.two{
		padding-top: 3.6rem;
	}
	.three{
		padding-top: 0;
	}
.two.no-active h2,
.two.no-active p,
.two.no-active .pic-area .pic,
.two.no-active .pic-area:before,
.two.no-active .pic-area:after{
	opacity: 0;
	visibility: hidden;
	transition: .15s all ease-in;
}
.two .catch-copy{
	align-items: center !important;
	display: block;
	background: #00a0e9;
	padding: .3em;
}
.two .catch-copy span{
	font-size: 1.8rem;
	margin-bottom: 0;
	padding: 0;
	display: inline;
}
.two mark{
	background: none;
	font-weight: 900;
	color: #fc5151;
}
	.two h2{
		margin-block: 1.8rem;
		font-size: 1.8rem;
	}

.two h2,
.three h2,
.two .catch-copy{
	transform: scale(.95);
	transition: .05s transform ease-in, .05s opacity ease-in;
	transition-delay: .6s;
	opacity: 0;
}
.loaded.count-comp .two.active h2,
.loaded.count-comp .three.active h2,
.two .catch-copy{
	opacity: 1;
	transform: scale(1);
	visibility: visible;
}
.two h2 img,
.three h2 img{
	display: block;
	width: 100%;
}

.two p.medium{
	text-align: center;
	font-size: min(2rem, 2.604vh);
	line-height: 2;
	letter-spacing: .05em;
	margin-bottom: min(2.5rem, 3.255vh);
	position: relative;
	z-index: 9;
}
.two p.medium,
.three p.bold{
	transform: translateY(min(2rem, 2.604vh));
	transition: .1s transform ease-in, .1s opacity ease-in;
	transition-delay: .65s;
}

.loaded.count-comp .two.active p.medium,
.loaded.count-comp .three.active p.bold{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
}
	.two p{
		padding-inline: 6rem;
		font-size: 1.5rem !important;
	}
	.two p.medium{
		margin-top: 3rem;
	}
	.two p.caption{
		font-size: 80% !important;
	}
.two p.ekichika{
	width: min(35.5rem, 46.223vh);
	margin-top: min(1rem, 1.302vh);
	transition: .2s opacity ease-in;
	transition-delay: .8s;
}
.loaded.count-comp .two.active p.ekichika{
	opacity: 1;
	visibility: visible;
}

	.two .pic-area{
		position: absolute;
		top: 23.6rem;
	}
	.two .pic01{
		width: 10rem;
		left: -3rem;
	}
	.two .pic02{
		width: 7.5rem;
		right: -2rem;
	}
	.two .pic-area .pic{
		position: relative;
		z-index: 9;
	}
.two .pic-area .pic,
.three li{
	transform: translateY(1.5rem);
	transition: .15s opacity ease-in, .15s transform ease-in;

}
.three .catch-copy02{
	position: relative;
	left: auto;
	right: auto;
	top: auto;
	bottom: auto;
	width: 100%;
	font-size: 1.7rem;
}
.three li{
	visibility: hidden;
	opacity: 1;
}
.two .pic-area.pic01:before{
	content: "";
	display: block;
	width: min(27.2rem, 35.416vh);
	height: min(21.9rem, 28.515vh);
	position: absolute;
	top: min(5.4rem, 7.031vh);
	left: max(-8.5rem, -11.067vh);
	background: url(../images/mv-sec02-line01.png) no-repeat;
	background-size: 100% auto;
	z-index: 1;

	transform: scale(0);
	transform-origin: right top;
	transition: .15s transform ease-in, .15s opacity ease-in;
	transition-delay: 1s;
}
.two .pic-area.pic02:before{
	content: "";
	display: block;
	width: min(24.6rem, 32.031vh);
	height: min(20.4rem, 26.562vh);
	position: absolute;
	top: min(3.6rem, 4.687vh);
	right: max(-6rem, -7.812vh);
	background: url(../images/mv-sec02-line02.png) no-repeat;
	background-size: 100% auto;
	z-index: 1;

	transform: scale(0);
	transform-origin: right top;
	transition: .15s transform ease-in, .15s opacity ease-in;
	transition-delay: 1.2s;
}
.two .pic-area:after{
	content: "";
	display: block;
	width: min(12.5rem, 16.276vh);
	height: min(3.6rem, 4.687vh);
	border-radius: 50%;
	position: absolute;
	bottom:max( -.6rem, -.781vh);
	left: 0;
	right: 0;
	margin: auto;
	background: linear-gradient(90deg, #fbac8c, #ff8b88);

	transtion: .3s all ease-in;
	transform: scale(0);
	transition: .2s transform ease-in, .3s opacity ease-in;
}
.two .pic01:after{
	transition-delay: 1s;
}
.two .pic02:after{
/*
	right: max(-1rem, -1.302vh);
*/
	right: 0;
	left: auto;
	background: linear-gradient(-90deg, #79b2dc, #73d4da);

	transition-delay: 1.1s;
}

.loaded.count-comp .two.active .pic01 .pic,
.loaded.count-comp .three.active li:nth-of-type(1){
	transition-delay: 1.2s;
}
.loaded.count-comp .two.active .pic02 .pic,
.loaded.count-comp .three.active li:nth-of-type(2){
	transition-delay: 1.4s;
}
.loaded.count-comp .two.active .pic-area .pic,
.loaded.count-comp .three.active li{
	transform: translateY(0);
	visibility: visible;
	opacity: 1;
}

.loaded.count-comp .two.active .pic01:before,
.loaded.count-comp .two.active .pic02:before{
	visibility: visible;
	opacity: 1;
	transform: scaleX(1);
}
.loaded.count-comp .two.active .pic01:after,
.loaded.count-comp .two.active .pic02:after{
	visibility: visible;
	opacity: 1;
	transform: scale(1);
}
/* +++.three+++ */
	.three h2{
		font-size: 1.7rem;
		position: relative;
		z-index: 9;
		visibility: hidden;
		opacity: 0;
	}
	.three p.bold{
		font-size: 1.5rem;
		line-height: 1.75;
		margin-block: 1rem 1rem;
		position: relative;
		z-index: 9;
		visibility: hidden;
		opacity: 0;
		letter-spacing: 0;
	}

	.three ul{
		display: block;
		max-width: 60%;
	}
	.three li{
		width: 100%;
		margin-top: 1.5rem;
		opacity: 0;
	}
	.three li h3{
		font-size: 1.4rem;
		line-height: 1.35;
	}

	.three li p{
		padding: 1em;
		line-height: 1.75;
		text-align: left !important;
		font-size: 85%;
	}
}









/* +++.features+++ */
.features{
	padding-top: 0;
}
.comment01{
	margin-bottom: 1em;
	font-size: 1.8rem;
}
.comment01 .text-red{
	font-size: 125%;
	padding-inline: .25em;
}
.comment02{
	width: fit-content;
	font-size: 2.4rem;
	margin: 0 auto 6rem;
	position: relative;
}
.comment02 .text-lightblue{
	font-size: 150%;
}
.comment02 .slide-up{
	transform: translateY(3em);
}
/*
.circle-wrap {
	margin: 0 auto;
	padding: 0 0 5rem 0;
	width: 500px;
	z-index: 3;
	opacity: 0;
	transform: translateY(-100px) scale(0.8);
	transition: opacity 0.5s ease-out, transform 0.5s ease-out;
	transform-origin: center top;
	margin-top: 6em;
}
.circle-wrap.is-shown {
  opacity: 1;
  transform: translateY(0) scale(0.9);
}
.circle-area {
	text-align: center;
}
.large-circle {
	border: 7px dotted #18436e;
	border-radius: 50%;
	width: 350px;
	height: 350px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-40%);
	animation: rotate-circle 30s linear infinite;
}
@keyframes rotate-circle {
	from {
		transform: translateX(-50%) translateY(-40%) rotate(0deg);
	}
	to {
		transform: translateX(-50%) translateY(-40%) rotate(360deg);
	}
}
.circle-text {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	width: 120%;
}
.circle-text p {
	font-size: 1.8rem;
}
.circle-features {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10rem 16rem;
	justify-items: center;
}
.circle-feature {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.circle-feature:nth-child(1) {
	grid-column: 1 / -1;
	justify-self: center;
}
.circle-feature:nth-child(2),
.circle-feature:nth-child(3) {
	grid-column: span 1;
}
.small-circle {
	width: 150px;
	height: 150px;
	border-radius: 50%;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.catch-copy01 {
	font-size: 2rem;
}
.catch-copy02 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-25%);
	width: 200%;
	font-size: 1.5rem;
}
.back-color01 { background-color: #18436e; }
.back-color02 { background-color: #227c54; }
.back-color03 { background-color: #8e1028; }
.font-color01 { color: #18436e; }
.font-color02 { color: #227c54; }
.font-color03 { color: #8e1028; }
.text-outline01 {
	-webkit-text-stroke: 5px #18436e;
	text-stroke: 5px #18436e;
	paint-order: stroke;
}
*/



.circle-wrap2 {
	margin: 10rem auto 0;
	/*padding: 0 0 5rem 0;*/
	width: 500px;
	z-index: 3;
	opacity: 0;
	transform: translateY(-100px) scale(0.8);
	transition: opacity 0.5s ease-out, transform 0.5s ease-out;
	transform-origin: center top;
}
.circle-wrap2.is-shown {
  opacity: 1;
  transform: translateY(0) scale(0.9);
}
.circle-area2 {
	text-align: center;
}
.large-circle2 {
	border: 7px dotted #18436e;
	border-radius: 50%;
	width: 350px;
	height: 350px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-40%);
	animation: rotate-circle2 30s linear infinite;
}
@keyframes rotate-circle2 {
	from {
		transform: translateX(-50%) translateY(-40%) rotate(0deg);
	}
	to {
		transform: translateX(-50%) translateY(-40%) rotate(360deg);
	}
}
.circle-text2 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	width: 120%;
}
.circle-text2 p {
	font-size: 1.8rem;
}
.circle-features2 {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10rem 16rem;
	justify-items: center;
}
.circle-feature2 {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.circle-feature2:nth-child(1) {
	grid-column: 1 / -1;
	justify-self: center;
}
.circle-feature2:nth-child(2),
.circle-feature2:nth-child(3) {
	grid-column: span 1;
}
.small-circle2 {
	width: 150px;
	height: 150px;
	border-radius: 50%;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.catch-copy01-2 {
	font-size: 2rem;
}
.catch-copy02-2 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-25%);
	width: 200%;
	font-size: 1.5rem;
}
.back-color01-2 { background-color: #18436e; }
.back-color02-2 { background-color: #227c54; }
.back-color03-2 { background-color: #8e1028; }
.font-color01-2 { color: #18436e; }
.font-color02-2 { color: #227c54; }
.font-color03-2 { color: #8e1028; }
.text-outline01-2 {
	-webkit-text-stroke: 5px #18436e;
	text-stroke: 5px #18436e;
	paint-order: stroke;
}
.text-outline02-2 {
	-webkit-text-stroke: 5px #227c54;
	text-stroke: 5px #227c54;
	paint-order: stroke;
}
.text-outline03-2 {
	-webkit-text-stroke: 5px #8e1028;
	text-stroke: 5px #8e1028;
	paint-order: stroke;
}
.text-outline04-2 {
	-webkit-text-stroke: 4px #fff;
	text-stroke: 4px #fff;
	paint-order: stroke;
}


.text-outline02 {
	-webkit-text-stroke: 5px #227c54;
	text-stroke: 5px #227c54;
	paint-order: stroke;
}
.text-outline03 {
	-webkit-text-stroke: 5px #8e1028;
	text-stroke: 5px #8e1028;
	paint-order: stroke;
}
.text-outline04 {
//	-webkit-text-stroke: 4px #fff;
	-webkit-text-stroke: 5px #47b9af;
	text-stroke: 4px #fff;
	paint-order: stroke;
}
.text-outline05 {
	-webkit-text-stroke: 4px #fff;
	text-stroke: 4px #fff;
	paint-order: stroke;
}

.feature{
	width: 100%;
	position: relative;
	margin-bottom: 7.2rem;
	align-items: center;
}
.feature .pic-area{
	position: relative;
	width: min(43.548rem, calc(95vw * .382));
	height: min(43.548rem, calc(95vw * .382));
}
.feature .text{
	width: calc(61.8% - 7.2rem);
}
.feature:nth-of-type(2n+1){
	flex-direction: row-reverse;
}

.feature h3{
	font-size: 2.2rem;
	line-height: 1.75;
	margin-bottom: 1.8rem;
}
.feature p{
	font-size: 1.5rem;
}
.feature .pic{
	position: absolute;
}
.feature:nth-of-type(1) .pic01,
.feature:nth-of-type(3) .pic01{
	left: 0;
	top: 0;
	width: 61.8%;
}
.feature:nth-of-type(1) .pic02,
.feature:nth-of-type(3) .pic02{
	right: 0;
	bottom: 0;
	width: 61.8%;
}
.feature:nth-of-type(2) .pic01{
	left: 0;
	top: 0;
	width: 80%;
}
.feature:nth-of-type(2) .pic02{
	right: 0;
	bottom: 0;
	width: 80%;
}
.feature:nth-of-type(4) .pic01{
	left: 0;
	top: 0;
	width: 80%;
}
.feature:nth-of-type(4) .pic02{
	right: 0;
	bottom: 0;
	width: 80%;
}

.feature h3 .slide-up{
	transform: translateY(3em);
}
.feature p .slide-up{
	transform: translateY(100%);
}

mark{
	padding: 0 .5em;
	position: relative;
	font-size: 110%;
	background: none;
}
mark:before{
	content: "";
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: #e8ff00;
	background: #fcff6a;
	mix-blend-mode: darken;
}
#features .slide-left-open:before,
#features .slide-right-open:before,
#features .slide-top-open:before,
#features .slide-bottom-open:before{
	background: #f5f8fa;
}





/* +++.philosophy+++ */
.philosophy p.comment02{
	font-size: 1.8rem;
	margin-bottom: 3rem;
	line-height: 1.75;
}

.comment03{
	font-size: 1.8rem;
	line-height: 1.75;
	margin: 4rem auto 3rem;
}
.comment03 mark{
	font-size: 110%;
	margin: 0 .25em;
}
.case{
	width: calc(50% - 2.4rem);
	border: 2px solid #bbb;
}
.case02{
	border-color: #f68026;
}
.case .pic{
	width: 100%;
	padding: 2.4rem;
}

.case .caption{
	font-size: 80%;
}
.philosophy div.s-between{
	max-width: 100rem;
	align-items: stretch;
}
.case h4{
	font-size: 1.7rem;
	text-align: center;
	padding: 1.2rem .6rem;
	line-height: 1.5;
	color: #fff;
	background: #bbb;
	width: 100%;
}


.case02 h4{
	background: #f68026;
}
.case .text{
	padding: 2rem;
}
.case .text p{
	font-size: 1.4rem;
}
.caption{
	font-size: 80%;
	margin-top: 1.5em;
	padding-left: 1em;
	text-indent: -1em;
	display: block;
}
.caption:before{
	content: "※";
	display: inline;
}
.arrow{
	margin: 3.6rem auto;
	position: relative;
}
.arrow .pic{
	width: 12rem;
	margin: auto;
	opacity: .5;
}
.arrow-text{
	font-size: 2.4rem;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
.case mark{
	background: #e8ff00;
}
.case mark:before{
	display: none;
}

.curriculum{
	align-items: flex-start !important;
	margin-bottom: 9.6rem;
}
.curriculum:last-of-type{
	margin-bottom: 4.8rem;
}
.curriculum:nth-of-type(2n+1){
	flex-direction: row-reverse;
}

.curriculum .text{
	width: calc(65% - 4.8rem);
	margin-top: 5.4rem;
}

.curriculum .text{
	margin-top: 3.6rem;
	padding: 3.6rem;
	background: #eee;
	width: calc(65% + 10vw);
	background: #f5faf9;
}
.curriculum:nth-of-type(2n+1) .text{
	margin-right: -10vw;
	padding-right: calc(3.6rem + 10vw);
	background: #f6f3f0;
}
.curriculum:nth-of-type(2n) .text{
	margin-left: -10vw;
	padding-left: calc(3.6rem + 10vw);
}

.curriculum .pic{
	width: 35%;
}

.curriculum p{
	font-size: 1.5rem;
}
.curriculum h4{
	line-height: 1.75;
	font-size: 2rem;
	margin-bottom: 1.6rem;
	font-weight: 500;
}
.curriculum .en{
	color: #62c1b1;
	margin-bottom: .8rem;
	line-height: .8;
	color: #39b6af;
}
.curriculum:nth-of-type(2n+1) .en{
	color: #f97520;
}


/* +++++こんなに違うのセクション+++++++ */
.lead-area{
	margin-bottom: 3rem;
}
.lead{
	padding: .75em;
	background: #d71010 !important;
	font-size: 135%;
	color: #fff;
}
.lead-area p{
	padding-left: 1em;
	font-size: 112.5%;
}


/* +++#kyouzai+++ */
.text-area {
	min-width: 1200px;
}
.cycle-wrap {
	padding: 0 0 0 2rem;
	opacity: 0;
	transform: scale(0.85);
}
.cycle-wrap.is-shown {
	opacity: 1;
	animation: zoomInAnime 0.5s forwards;
}
@keyframes zoomInAnime {
	from {
		transform: scale(0.85);
	}
	to {
		transform: scale(1);
	}
}
.cycle-background {
	transform: scale(0.85);
	opacity: 0.5;
}
.cycle-rotate {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%) scale(0.75);
	animation: rotate-circle 8s linear infinite;
}
@keyframes rotate-circle {
	from {
		transform: translateX(-50%) translateY(-50%) scale(0.75) rotate(0deg);
	}
	to {
		transform: translateX(-50%) translateY(-50%) scale(0.75) rotate(360deg);
	}
}
.cycle-text-wrap p {
	position: absolute;
	font-size: 2rem;
	line-height: 1.25;
	color: #fff;
}
.cycle-text01 {
	top: 110px;
	left: 145px;
}
.cycle-text02 {
	top: 160px;
	right: 135px;
}
.cycle-text03 {
	top: 235px;
	left: 140px;
}
.cycle-text04 {
	top: 260px;
	right: 135px;
}
.text-outline01 {
	-webkit-text-stroke: 5px #53b9e9;
	text-stroke: 5px #53b9e9;
	paint-order: stroke;
}
.text-outline02 {
	-webkit-text-stroke: 5px #2398aa;
	text-stroke: 5px #2398aa;
	paint-order: stroke;
}
.text-outline03 {
	-webkit-text-stroke: 5px #1bc0d6;
	text-stroke: 5px #1bc0d6;
	paint-order: stroke;
}
.text-outline04 {
//	-webkit-text-stroke: 5px #fff;
	-webkit-text-stroke: 5px #47b9af;
	text-stroke: 5px #47b9af;
	paint-order: stroke;
}

.text-outline05 {
	-webkit-text-stroke: 4px #fff;
	text-stroke: 4px #fff;
	paint-order: stroke;
}

/* +++#curriculum+++ */
.curriculum-list{
	justify-content: center;
	max-width: 140.4rem;
}
.curriculum-list li{
	width: 25%;
	padding: 0 1.8rem 5.4rem;
	overflow: hidden;
	position: relative;
}
.curriculum-list li:nth-of-type(n+5){
	padding-bottom: 0;
}
.curriculum-list .pic {
	position: relative;
	overflow: hidden;
}
.curriculum-list .pic:before {
	content: "";
	display: block;
	width: 120%;
	height: 100%;
	position: absolute;
	left: -10%;
	top: 0;
	background: #3dd2b7;
	transform: skew(-15deg, 0) scale(0, 1);
	transition: .3s all ease;
	opacity: 0;
	z-index: 2;
}
.curriculum-list li:hover .pic:before {
	transform: skew(-15deg, 0) scale(1, 1);
	opacity: 0.8;
}
.nav-curriculum-list .pic img {
	display: block;
	width: 100%;
	transition: .3s ease;
	position: relative;
	z-index: 1;
}
.curriculum-list h3{
	font-size: 1.7rem;
	line-height: 1.5;
	margin: 2.4rem 0 1rem;
}
.curriculum-list p{
	font-size: 1.4rem;
}
.curriculum-list .pic .en {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: auto;
	font-weight: 300;
	font-size: 1.4rem;
	letter-spacing: .05em;
	color: #fff;
	z-index: 3;
	transition: .3s opacity ease;
	transition-delay: .3s;
	opacity: 0;
	visibility: hidden;
}
.curriculum-list li:hover .pic .en {
	opacity: 1;
	visibility: visible;
}
.curriculum-list .txt {
	position: relative;
	z-index: 9;
	color: #131313;
}












/* +++ .voice +++ */
.pswp{
	z-index: 99999;
}
.voice-list li{
	width: calc(25% - 2.7rem);
	height: min(calc((95vw / 4) - 2.7rem), 25.8rem);
	overflow: hidden;
	margin-bottom: 3.6rem;
	position: relative;
}
.voice-list li:before{
	background: #f5f8fa;
}
.voice-list li:not(:nth-of-type(4n)){
	margin-right: 3.6rem;
}
.voice-list li *{
	display: block;
	width: 100%;
	height: 100%;
}
.voice-list img{
	display: block;
	transition: .3s all ease;
}
.voice-list a:hover img{
	transform: scale(1.05);
}





/* +++training+++ */
.training-list{
	justify-content: center;
	max-width: 140.4rem;
}
.training-list li{
	width: 25%;
	padding: 0 1.8rem 5.4rem;
	overflow: hidden;
	position: relative;
}
.training-list li:nth-of-type(n+5){
	padding-bottom: 0;
}
.training-list h3{
	font-size: 1.7rem;
	line-height: 1.5;
	margin: 2.4rem 0 1rem;
}
.training-list p{
	font-size: 1.4rem;
}

/* +++school-slide01+++ */
.school-slide01{
	transition: .8s all ease;
}
.portfolio{
	padding-inline: 0;
}




.school-slide01 a{
	display: block;
	position: relative;
}
.school-slide01 a h3{
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	transition: .3s all ease;
	transition-delay: 0;
	visibility: hidden;
	opacity: 0;
	font-size: 1.6rem;
}
.school-slide01 a:hover h3{
	opacity: 1;
	visibility: visible;
	transition-delay: .3s;
}
.school-slide01 li .pic{
	position: relative;
	overflow: hidden;
}
.school-slide01 .pic{
	height: calc(100vw / 3.5 / 3 * 2);
}

.school-slide .pic img{
	height: 100%;
	object-position: center top;
}

.school-slide01 li .pic:before{
	font-family: 'Outfit', 'Zen Kaku Gothic New', YuGothic, 游ゴシック, メイリオ, Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
	--spacing: .1em;
	font-weight: 400;
	color: #fff;
	content: "";
	display: flex;
	justify-content: center;
	align-items: center;
	width: 120%;
	height: 100%;
	position: absolute;
	background: #3dd2b7;
	transform: skew(-15deg, 0) scale(0,1);
	left: -10%;
	top: 0;
	transition: .3s all ease;
	opacity: 0;
}
.school-slide01 li:hover .pic:before{
	transform: skew(-15deg, 0) scale(1,1);
	opacity: .85;
}


/* +++school-slide01+++ */
.outline .sec-title01{
	width: calc(30% - 2.4rem);
}
.outline .content{
	width: 70%;
}
.outline table{
	width: 100%;
	line-height: 1.75;
}
.outline th{
	font-weight: 500;
	text-align: left;
	vertical-align: top;
	width: 30%;
	border-bottom: 1px solid #434343;
	padding: 1.8rem 1.2rem;
	font-size: 1.5rem;
}
.outline td{
	width: 70%;
	border-bottom: 1px solid #ccc;
	padding: 1.8rem 1.2rem;
	font-size: 1.5rem;
}
.outline td dl:not(:last-of-type){
	margin-bottom: 1.5em;
}
.outline th:nth-of-type(1){
	border-top: 1px solid #434343;
}
.outline td:nth-of-type(1){
	border-top: 1px solid #ccc;
}

.outline td a{
	display: inline-block;
	width: fit-content;
	position: relative;
}
.outline td a[target="_blank"]:after{
	content: "";
	display: inline-block;
	width: .8em;
	height: .8em;
	margin-left: .5em;
	background: url(../images/new-window-icon01.svg) no-repeat;
	background-size: 100% auto;
	background-position: center center;
}
.outline td a:before{
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background: #434343;
	position: absolute;
	left: 0;
	bottom: 0;
	transition: .3s transform ease;
	transform-origin: left top;
}

.outline td a:hover:before{
	transform-origin: right top;
	transform: scaleX(0);

}


/* +++access+++ */
.map-area:not(:last-of-type){
	margin-bottom: 4.8rem;
}
.map-area{
	align-items: center;
}
.map-area .text{
	width: calc(50% + 10vw);
	margin-right: -10vw;
	padding: 3.6rem calc(3.6rem + 10vw) 3.6rem 3.6rem;
	background: #f2f2ed;
	font-size: 1.5rem;

	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;

	height: min(calc(45vw / 16 * 9 + 7.2rem), calc(32rem + 7.2rem));
}
.googlemap{
	width: 50%;
	height: min(calc(45vw / 16 * 9), 32rem);
}
.googlemap>iframe{
	display: block;
	width: 100%;
	height: 100%;
}
.access .slide-left-open:before{
	background: #f5f8fa;
	z-index: 999;
}




/* +++++++++++online course一覧++++++++++ */
/* +++#course+++ */
#course{
	padding-inline: 1.25vw;
}
.course{
	padding-inline: 1.25vw;
}
.course .pic{
	position: relative;
	overflow: hidden;
}
.course .pic:before{
	content: "";
	display: block;
	width: 120%;
	height: 100%;
	position: absolute;
	background: #3dd2b7;
	transform: skew(-15deg, 0) scale(0, 1);
	left: -10%;
	top: 0;
	transition: .3s all ease;
	opacity: 0;
}
.course .pic .en{
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: auto;
	font-weight: 300;
	font-size: 1.4rem;
	letter-spacing: .05em;
	transition: .3s opacity ease;
	transition-delay: .3s;
	opacity: 0;
	visibility: hidden;
}
.course a:hover .pic .en{
	opacity: 1;
	visibility: visible;
}
.course a:hover .pic:before{
	transform: skew(-15deg, 0) scale(1,1);
	opacity: .65;
}
.course .txt{
	position: relative;
	z-index: 9;
	padding-top: 2.4rem;
}
.course h3{
	font-size: 2rem;
	line-height: 1.75;
	position: relative;
}
.course .curriculum-name {
	margin: 1.5rem 0 0;
}
.course .txt-space {
	padding: 0 0 0 0.5rem;
	line-height: 1.2;
	font-weight: 400;
}
.course dl{
	margin-bottom: 2.4rem;
	font-size: 1.2rem;
}
.course dt{
	position: relative;
	margin-bottom: 1.2rem;
	font-weight: 500;
	width: 6em;
	height: 1.8em;
	border-radius: .9em;
	border: 1px solid #434343;
	display: flex;
	align-items: center;
	justify-content: center;
}
.course dt.wide-icon {
	width: 9.5em;
}
.course dl:nth-of-type(2) dd{
	font-size: 1.3rem;
}
.course dl dd{
	font-size: 1.8rem;
}

.philosophy .slide-left-open:before{
	background: #f5f8fa !important;
}



@media screen and (max-width: 768px){

	.school-main-pic01 img,
	.school-main-pic02 img {
		width: 100%;
	}

/* +++#features+++ */
	.comment02{
		font-size: 1.6rem;
		margin: 0 auto 3.6rem;
	}
	.comment02 .text-red{
		font-size: 125%;
	}
	.comment02 .slide-up{
		transform: translateY(5em);
	}

	.feature-area{
		display: block;
	}
	.feature{
		width: 100%;
	}
	.feature .pic-area{
		width: calc(100% - 4rem);
		height: calc(100vw - 8rem);
		margin: 0 auto 2.4rem;
	}

	.feature h3{
		font-size: 1.6rem;
		margin-bottom: 1.2rem;
	}
	.feature p{
		font-size: 1.3rem;
	}
	.feature:nth-of-type(2){
		margin-top: 6rem;
	}
	.feature:nth-of-type(3){
		margin-top: 6rem;
	}
	.feature .text {
		width: 100%;
	}
	mark{
		display: inline-block;
		padding: 0 .25em;
		font-size: 105%;
	}


/* +++.philosophy+++ */
	.philosophy{
		padding-inline: 0;
	}
	.philosophy p.comment02{
		font-size: 1.6rem;
		margin-bottom: 1.2rem;
		line-height: 1.75;
	}

	.comment03{
		font-size: 1.6rem;
		line-height: 1.75;
		margin: 2.4rem auto 1.8rem;
	}
	.comment03 mark{
		font-size: 105%;
		margin: 0 .1em;
	}
	.case{
		width: 100%;
		border: 3px solid #bbb;
	}

	.philosophy div.s-between{
		display: block;
		max-width: 100%;
		padding-inline: 2rem;
	}
	.case h4{
		font-size: 1.5rem;
		text-align: center;
		padding: .8rem .4rem;
	}

	.case02{
		border-color: #f68026;
		margin-top: 1.8rem;
	}

	.case .text{
		padding: 1.5rem;
	}
	.case .text p{
		font-size: 1.3rem;
	}

	.arrow{
		margin: 1.8rem auto;
	}
	.arrow .pic{
		width: 8rem;
	}
	.arrow-text{
		font-size: 1.6rem;
	}


	.curriculum{
		align-items: center !important;
		flex-direction: column-reverse;
		margin-bottom: 4.8rem;
		padding-inline: 0 !important;
	}
	.curriculum:last-of-type{
		margin-bottom: 3.6rem;
	}
	.curriculum:nth-of-type(2n+1){
		flex-direction: column-reverse;
	}

	.curriculum .text{
		width: 100%;
		margin-top: -4.8rem;
	}

	.curriculum .text{
		padding: 6.8rem 2rem 2rem;
	}
	.curriculum:nth-of-type(2n+1) .text{
		margin-right: 0;
		padding-right: 2rem;
	}
	.curriculum:nth-of-type(2n) .text{
		margin-left: 0;
		padding-left: 2rem;
	}
	.curriculum .pic{
		width: 61.8%;
		margin: 0 auto;
		position: relative;
		z-index: 9;
	}

	.curriculum p{
		font-size: 1.3rem;
	}
	.curriculum h4{
		line-height: 1.5;
		font-size: 1.7rem;
		margin-bottom: 1.2rem;
	}
	.curriculum .en{
		font-size: 1.2rem;
	}


/* +++++こんなに違うのセクション+++++++ */
	.lead-area{
		margin-bottom: 1.8rem;
	}
	.lead{
		font-size: 110%;
		width: calc(100% - 3rem);
		text-align: center;
		margin-bottom: 1rem;
	}
	.lead-area p{
		padding-inline: 1.5rem;
		font-size: 100%;
		font-weight: 500;
	}
	.case .pic{
		padding: 1.5rem;
	}




/* +++#kyouzai+++ */
	.text-area {
		min-width: auto;
	}
	.cycle-wrap {
		margin: 0 auto;
		padding: 0;
		width: 100%;
	}
	.cycle-background {
		transform: scale(0.75);
	}
	.cycle-background img {
		width: 100%;
		height: auto;
	}
	.cycle-rotate {
		transform: translateX(-50%) translateY(-50%) scale(0.65);
		animation: rotate-circle 8s linear infinite;
	}
	@keyframes rotate-circle {
		from {
			transform: translateX(-50%) translateY(-50%) scale(0.65) rotate(0deg);
		}
		to {
			transform: translateX(-50%) translateY(-50%) scale(0.65) rotate(360deg);
		}
	}
	.cycle-text-wrap p {
		font-size: 1.35rem;
	}
	.cycle-text01 {
		top: 105px;
		left: 135px;
	}
	.cycle-text02 {
		top: 145px;
		right: 130px;
	}
	.cycle-text03 {
		top: 210px;
		left: 130px;
	}
	.cycle-text04 {
		top: 230px;
		right: 120px;
	}




/* +++#curriculum+++ */
	.curriculum-list{
		justify-content: space-between;
		max-width: 100%;
	}
	.curriculum-list li{
		width: calc(50% - 1rem);
		padding: 0 0 4rem;
	}
	.curriculum-list li:nth-of-type(n+5){
		padding-bottom: 4rem;
	}
	.curriculum-list h3{
		font-size: 1.6rem;
		line-height: 1.5;
		margin: 1.8rem 0 1rem;
	}
	.curriculum-list p{
		font-size: 1.3rem;
	}





/* +++ .voice +++ */
	.voice-list{
		justify-content: space-between;
	}
	.voice-list li{
		width: calc(50% - 1rem);
		height: calc(50vw - 2rem);
		margin: 0 0 2rem !important;
	}

/* +++training+++ */
	.training-list{
		justify-content: space-between;
		max-width: 100%;
	}
	.training-list li{
		width: calc(50% - 1rem);
		padding: 0 0 4rem;
	}
	.training-list li:nth-of-type(n+5){
		padding-bottom: 4rem;
	}
	.training-list h3{
		font-size: 1.6rem;
		line-height: 1.5;
		margin: 1.8rem 0 1rem;
	}
	.training-list p{
		font-size: 1.3rem;
	}
	.training{
		padding-bottom: 2rem;
	}





/* +++school-slide01+++ */
	.school-slide01{
		padding-bottom: 0;
	}
	.school-slide01 .pic{
		height: calc(100vw / 1.25 / 3 * 2);
	}


/* +++outline+++ */
	th,
	td{
		padding: 1.2rem .8rem !important;
		font-size: 1.3rem !important;
		line-height: 1.75 !important;
	}
	th{
		width: 35% !important;
	}
	td{
		width: 65% !important;
	}

	.outline .sec-title01{
		width: 100%;
	}
	.outline .content{
		width: 100%;
	}





/* +++access+++ */
	.access{
		padding-inline: 0;
		padding-bottom: 0;
	}
	.map-area:not(:last-of-type){
		margin-bottom: 4.8rem;
	}
	.map-area{
		flex-direction: column-reverse;
	}
	.map-area .text{
		width: 100%;
		margin-right: 0;
		padding: 6.8rem 2rem 3.6rem;
		font-size: 1.3rem;
		margin-top: -4.8rem;
		height: auto;
	}
	.map-area .button01{
		margin-top: 1.8rem;
	}




	.googlemap{
		width: calc(100vw - 4rem);
		height: calc((100vw - 4rem) / 16 * 9);
		position: relative;
		z-index: 99;
	}





/* +++#course (オンラインコース一覧)+++ */
	#course{
		padding-inline: 2rem;
	}
	.course{
		padding-inline: 2rem;
	}
	.course{
		padding-inline: 0;
		width: 100%;
		margin-bottom: 0;
	}

	.course .pic .en{
		font-size: 1.2rem;
	}

	.course h3{
		font-size: 1.9rem;
		width: calc(100% - 4rem);
		/*margin-top: -1.8em;*/
	}


	.course dl{
		margin-top: 2rem;
		font-size: 1.4rem;
	}
	.course dt{
		margin-bottom: 1.2rem;
	}

	.course dl:nth-of-type(2) dd{
		font-size: 1.5rem;
	}
	.course dl dd{
		font-size: 1.8rem;
	}
}